{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "429d6ca6",
   "metadata": {},
   "source": [
    "# Example: WeightedSHAP on the fraud dataset\n",
    "\n",
    "- In this notebook, we introduce weightedSHAP, which provides a generalized feature attribution method."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9f99822a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys, os\n",
    "import numpy as np\n",
    "import pickle \n",
    "np.random.seed(2022)\n",
    "from analysis_utils import *\n",
    "\n",
    "sys.path.append('../weightedSHAP')\n",
    "import data, train, weightedSHAPEngine"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "157334be",
   "metadata": {},
   "source": [
    "## Load data\n",
    "- We use the fraud dataset (https://www.openml.org/search?type=data&status=active&id=42397).\n",
    "- A function `data.load_data` will load the `train`, `val`, `est`, and `test` datasets. \n",
    " - `train`: to train a model to explain\n",
    " - `val`: to optimize hyperparameters\n",
    " - `est`: to estimate coalition functions\n",
    " - `test`: to evaluate the quality of feature attributions "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "36f9d991",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------\n",
      "Load a dataset\n",
      "------------------------------\n",
      "--------------------------------------------------\n",
      "Fraud Detection\n",
      "--------------------------------------------------\n",
      "------------------------------\n",
      "Before adding noise\n",
      "Shape of X_train, X_val, X_est, X_test: (13310, 30), (1902, 30), (1902, 30), (1902, 30)\n",
      "------------------------------\n",
      "Rho: 0.0388\n",
      "After adding noise\n",
      "Shape of X_train, X_val, X_est, X_test: (13310, 90), (1902, 90), (1902, 90), (1902, 90)\n",
      "------------------------------\n"
     ]
    }
   ],
   "source": [
    "# Load dataset\n",
    "problem='classification' \n",
    "dataset='fraud'\n",
    "ML_model='boosting' \n",
    "(X_train, y_train), (X_val, y_val), (X_est, y_est), (X_test, y_test)=data.load_data(problem, dataset)    "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d203fb7",
   "metadata": {},
   "source": [
    "## Train a model to explain\n",
    " - This step is a typical routine in machine learning. Given training and validation datasets, we train a model. Our goal is to interpret this model by looking a particular prediction (i.e., a local attribution problem)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9e5c7be6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "------------------------------\n",
      "Train a model\n",
      "Train a model to explain: Boosting\n",
      "Training until validation scores don't improve for 25 rounds\n",
      "Early stopping, best iteration is:\n",
      "[12]\tvalid_0's binary_logloss: 0.646885\tvalid_0's binary_error: 0.0320715\n",
      "Elapsed time for training a model to explain: 1.21 seconds\n",
      "------------------------------\n"
     ]
    }
   ],
   "source": [
    "model_to_explain=train.create_model_to_explain(X_train, y_train, X_val, y_val, problem, ML_model)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f59c30c7",
   "metadata": {},
   "source": [
    "## Compute attributions and evaluate its performance\n",
    "- `weightedSHAPEngine.run_attribution_core` computes conditional expectation values $\\mathbb{E}[f(X) \\mid X_S = x_S]$ based on various weighted versions $\\phi_\\mathbf{w} (x_i) := \\sum_{j=1} ^{d} w_j \\Delta_{j}(x_i)$ of SHAP (Equation (5) of the paper). We consider a set $\\mathcal{W}$ which includes SHAP as well.\n",
    "- We store them in `exp_dict` which includes\n",
    " - `cond_pred_keep_absolute` (add features with large absolute values first)\n",
    " - `cond_pred_remove_absolute` (remove features with large absolute values first)\n",
    " - `pred_masking` (add features with large absolute values first and other featuers are masked with zero)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8c04071f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Elapsed time for training a surrogate model: 527.47 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  0%|                                                                                                                | 0/100 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0044481225297783\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1000 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  1%|█                                                                                                       | 1/100 [00:25<42:46, 25.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0102558569524647\n",
      "Total number of random sets: 1100, GR_stat: 1.0074160922051987\n",
      "Total number of random sets: 1200, GR_stat: 1.008655035366421\n",
      "Total number of random sets: 1300, GR_stat: 1.0063212384785707\n",
      "Total number of random sets: 1400, GR_stat: 1.0061500413389084\n",
      "Total number of random sets: 1600, GR_stat: 1.005908302141378\n",
      "Total number of random sets: 1700, GR_stat: 1.0041591841727189\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  2%|██                                                                                                    | 2/100 [01:14<1:03:43, 39.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 500, GR_stat: 1.0163095169574239\n",
      "Total number of random sets: 1000, GR_stat: 1.0077326128040351\n",
      "Total number of random sets: 1300, GR_stat: 1.0057636410103268\n",
      "Total number of random sets: 1400, GR_stat: 1.0057137346730483\n",
      "Total number of random sets: 1500, GR_stat: 1.005533623884607\n",
      "Total number of random sets: 1600, GR_stat: 1.0028695002518269\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  3%|███                                                                                                   | 3/100 [02:01<1:09:00, 42.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.007537805616862\n",
      "Total number of random sets: 1300, GR_stat: 1.0097895252454514\n",
      "Total number of random sets: 1400, GR_stat: 1.0071102232971398\n",
      "Total number of random sets: 1500, GR_stat: 1.0066231163509478\n",
      "Total number of random sets: 1600, GR_stat: 1.0058451299193336\n",
      "Total number of random sets: 1700, GR_stat: 1.0049397066816688\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  4%|████                                                                                                  | 4/100 [02:48<1:10:57, 44.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.0129614485568346\n",
      "Total number of random sets: 1000, GR_stat: 1.0069803259252674\n",
      "Total number of random sets: 1100, GR_stat: 1.003825994922321\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  5%|█████                                                                                                 | 5/100 [03:18<1:02:26, 39.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0121055740534584\n",
      "Total number of random sets: 1300, GR_stat: 1.0075818222030157\n",
      "Total number of random sets: 1400, GR_stat: 1.0042180086337975\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  6%|██████                                                                                                | 6/100 [03:57<1:01:37, 39.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0067372087682689\n",
      "Total number of random sets: 1200, GR_stat: 1.0047269236931053\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  7%|███████▎                                                                                                | 7/100 [04:31<58:06, 37.49s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0056031880385425\n",
      "Total number of random sets: 1300, GR_stat: 1.0048167678980615\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  8%|████████▎                                                                                               | 8/100 [05:07<56:45, 37.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0039283340513974\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1000 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      "  9%|█████████▎                                                                                              | 9/100 [05:32<50:34, 33.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0088069005196427\n",
      "Total number of random sets: 1200, GR_stat: 1.0109575981412975\n",
      "Total number of random sets: 1300, GR_stat: 1.0108422602798748\n",
      "Total number of random sets: 1400, GR_stat: 1.0067363181592395\n",
      "Total number of random sets: 1500, GR_stat: 1.0063427679837251\n",
      "Total number of random sets: 1600, GR_stat: 1.0080387453808237\n",
      "Total number of random sets: 1700, GR_stat: 1.0070187547714724\n",
      "Total number of random sets: 1800, GR_stat: 1.0078350972638002\n",
      "Total number of random sets: 1900, GR_stat: 1.0078990726504793\n",
      "Total number of random sets: 2000, GR_stat: 1.008705076994871\n",
      "Total number of random sets: 2100, GR_stat: 1.0070270901335705\n",
      "Total number of random sets: 2200, GR_stat: 1.0066545428158322\n",
      "Total number of random sets: 2300, GR_stat: 1.0059169955302456\n",
      "Total number of random sets: 2400, GR_stat: 1.0074335362704787\n",
      "Total number of random sets: 2500, GR_stat: 1.004683666708194\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 2600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 10%|██████████                                                                                           | 10/100 [06:42<1:06:38, 44.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0073943967325434\n",
      "Total number of random sets: 1100, GR_stat: 1.0070611466155788\n",
      "Total number of random sets: 1200, GR_stat: 1.005868538037139\n",
      "Total number of random sets: 1300, GR_stat: 1.007096443920144\n",
      "Total number of random sets: 1500, GR_stat: 1.0056325780827242\n",
      "Total number of random sets: 1700, GR_stat: 1.0041322092559037\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 11%|███████████                                                                                          | 11/100 [07:29<1:07:19, 45.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0086440081050232\n",
      "Total number of random sets: 1400, GR_stat: 1.004852536585263\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 12%|████████████                                                                                         | 12/100 [08:09<1:03:59, 43.63s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1200, GR_stat: 1.0041877425909496\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 13%|█████████████▍                                                                                         | 13/100 [08:43<59:17, 40.89s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.00916319534759\n",
      "Total number of random sets: 1100, GR_stat: 1.0051711761235942\n",
      "Total number of random sets: 1200, GR_stat: 1.0044004677502236\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 14%|██████████████▍                                                                                        | 14/100 [09:17<55:39, 38.83s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.008807840415017\n",
      "Total number of random sets: 1300, GR_stat: 1.009039127882593\n",
      "Total number of random sets: 1400, GR_stat: 1.007041359426327\n",
      "Total number of random sets: 1500, GR_stat: 1.004947944828726\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 15%|███████████████▍                                                                                       | 15/100 [10:00<56:45, 40.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0051914986606003\n",
      "Total number of random sets: 1300, GR_stat: 1.0049432824362792\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 16%|████████████████▍                                                                                      | 16/100 [10:38<55:12, 39.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.00764162885721\n",
      "Total number of random sets: 1300, GR_stat: 1.0063666849148758\n",
      "Total number of random sets: 1400, GR_stat: 1.0050069327147393\n",
      "Total number of random sets: 1500, GR_stat: 1.0033912771693596\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 17%|█████████████████▌                                                                                     | 17/100 [11:23<56:53, 41.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0104090310537186\n",
      "Total number of random sets: 900, GR_stat: 1.009577222410384\n",
      "Total number of random sets: 1300, GR_stat: 1.0047021240276328\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 18%|██████████████████▌                                                                                    | 18/100 [12:00<54:23, 39.80s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 600, GR_stat: 1.0128345602974922\n",
      "Total number of random sets: 1200, GR_stat: 1.004647941402032\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 19%|███████████████████▌                                                                                   | 19/100 [12:34<51:15, 37.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0141887285756508\n",
      "Total number of random sets: 1100, GR_stat: 1.006981123019112\n",
      "Total number of random sets: 1400, GR_stat: 1.0075119718761651\n",
      "Total number of random sets: 1500, GR_stat: 1.0044670950292958\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 20%|████████████████████▌                                                                                  | 20/100 [13:16<52:07, 39.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0057166369136559\n",
      "Total number of random sets: 1200, GR_stat: 1.0055963734277726\n",
      "Total number of random sets: 1400, GR_stat: 1.0040088810443757\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 21%|█████████████████████▋                                                                                 | 21/100 [13:57<52:20, 39.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0106807489522922\n",
      "Total number of random sets: 1000, GR_stat: 1.0065016731282717\n",
      "Total number of random sets: 1200, GR_stat: 1.0066290735204293\n",
      "Total number of random sets: 1300, GR_stat: 1.008592471456618\n",
      "Total number of random sets: 1400, GR_stat: 1.0055273538146696\n",
      "Total number of random sets: 1500, GR_stat: 1.0065703684802345\n",
      "Total number of random sets: 1600, GR_stat: 1.0068706589416965\n",
      "Total number of random sets: 1800, GR_stat: 1.005007664897396\n",
      "Total number of random sets: 1900, GR_stat: 1.0039603319606667\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 2000 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 22%|██████████████████████▋                                                                                | 22/100 [14:50<56:51, 43.73s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0064546357631465\n",
      "Total number of random sets: 1100, GR_stat: 1.0057191221141624\n",
      "Total number of random sets: 1300, GR_stat: 1.003612146173081\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 23%|███████████████████████▋                                                                               | 23/100 [15:29<54:12, 42.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0079515058084563\n",
      "Total number of random sets: 1000, GR_stat: 1.0115520616687976\n",
      "Total number of random sets: 1200, GR_stat: 1.009557789224087\n",
      "Total number of random sets: 1300, GR_stat: 1.0077647436300712\n",
      "Total number of random sets: 1600, GR_stat: 1.0059917916798926\n",
      "Total number of random sets: 1800, GR_stat: 1.0050048053576626\n",
      "Total number of random sets: 2000, GR_stat: 1.0033019740716334\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 2100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 24%|████████████████████████▏                                                                            | 24/100 [16:30<1:00:40, 47.90s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0061177109955217\n",
      "Total number of random sets: 1200, GR_stat: 1.0046811122922208\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 25%|█████████████████████████▊                                                                             | 25/100 [17:07<55:45, 44.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0066004321787703\n",
      "Total number of random sets: 1000, GR_stat: 1.0075254079858549\n",
      "Total number of random sets: 1200, GR_stat: 1.0072294978488503\n",
      "Total number of random sets: 1300, GR_stat: 1.0057368940142075\n",
      "Total number of random sets: 1400, GR_stat: 1.0064376946989482\n",
      "Total number of random sets: 1500, GR_stat: 1.0045975881782803\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 26%|██████████████████████████▊                                                                            | 26/100 [17:53<55:35, 45.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 600, GR_stat: 1.0109414650270536\n",
      "Total number of random sets: 900, GR_stat: 1.0069327841314861\n",
      "Total number of random sets: 1500, GR_stat: 1.0040756135268596\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 27%|███████████████████████████▊                                                                           | 27/100 [18:39<55:09, 45.33s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0046778965865621\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 28%|████████████████████████████▊                                                                          | 28/100 [19:13<50:18, 41.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.005335069833249\n",
      "Total number of random sets: 1100, GR_stat: 1.0042613699655698\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 29%|█████████████████████████████▊                                                                         | 29/100 [19:47<46:47, 39.55s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0100657782862619\n",
      "Total number of random sets: 1200, GR_stat: 1.0049861350534421\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 30%|██████████████████████████████▉                                                                        | 30/100 [20:24<45:15, 38.79s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0055734910163079\n",
      "Total number of random sets: 1100, GR_stat: 1.0072357047014102\n",
      "Total number of random sets: 1300, GR_stat: 1.006737897606606\n",
      "Total number of random sets: 1400, GR_stat: 1.0066811196814807\n",
      "Total number of random sets: 1500, GR_stat: 1.0037460301929062\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 31%|███████████████████████████████▉                                                                       | 31/100 [21:10<47:06, 40.96s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0128300392542124\n",
      "Total number of random sets: 900, GR_stat: 1.013219232665488\n",
      "Total number of random sets: 1000, GR_stat: 1.0107768168565767\n",
      "Total number of random sets: 1200, GR_stat: 1.0059487346106035\n",
      "Total number of random sets: 1300, GR_stat: 1.0074779171770747\n",
      "Total number of random sets: 1400, GR_stat: 1.004863553298431\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 32%|████████████████████████████████▉                                                                      | 32/100 [21:53<47:11, 41.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0070362075373218\n",
      "Total number of random sets: 1300, GR_stat: 1.005590248715996\n",
      "Total number of random sets: 1500, GR_stat: 1.004276546795165\n",
      "MCI score: 9000, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 33%|█████████████████████████████████▉                                                                     | 33/100 [22:39<47:58, 42.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0054346658720337\n",
      "Total number of random sets: 1100, GR_stat: 1.0070041677824928\n",
      "Total number of random sets: 1500, GR_stat: 1.0034465618901731\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 34%|███████████████████████████████████                                                                    | 34/100 [23:25<48:18, 43.91s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0140007688203232\n",
      "Total number of random sets: 1000, GR_stat: 1.006555087634423\n",
      "Total number of random sets: 1100, GR_stat: 1.0045008337498678\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 35%|████████████████████████████████████                                                                   | 35/100 [23:59<44:22, 40.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.006624879063219\n",
      "Total number of random sets: 1100, GR_stat: 1.008065430621247\n",
      "Total number of random sets: 1200, GR_stat: 1.0070569627872823\n",
      "Total number of random sets: 1400, GR_stat: 1.0049284694054266\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 36%|█████████████████████████████████████                                                                  | 36/100 [24:42<44:23, 41.61s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0078675014973795\n",
      "Total number of random sets: 1200, GR_stat: 1.0076672414058068\n",
      "Total number of random sets: 1300, GR_stat: 1.0064354907396365\n",
      "Total number of random sets: 1600, GR_stat: 1.0052223558632543\n",
      "Total number of random sets: 1700, GR_stat: 1.005095116691244\n",
      "Total number of random sets: 1800, GR_stat: 1.00393456407714\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 37%|██████████████████████████████████████                                                                 | 37/100 [25:37<47:56, 45.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0090151813915036\n",
      "Total number of random sets: 1200, GR_stat: 1.0047550427490493\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 38%|███████████████████████████████████████▏                                                               | 38/100 [26:15<44:30, 43.07s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0053209653688533\n",
      "Total number of random sets: 1200, GR_stat: 1.006896753366532\n",
      "Total number of random sets: 1400, GR_stat: 1.006713174394029\n",
      "Total number of random sets: 1500, GR_stat: 1.0052295920555787\n",
      "Total number of random sets: 1600, GR_stat: 1.0052178216978378\n",
      "Total number of random sets: 1800, GR_stat: 1.0057214456913028\n",
      "Total number of random sets: 1900, GR_stat: 1.0057141301964463\n",
      "Total number of random sets: 2000, GR_stat: 1.0036650462482697\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 2100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 39%|████████████████████████████████████████▏                                                              | 39/100 [27:16<49:19, 48.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0063766740264017\n",
      "Total number of random sets: 1200, GR_stat: 1.0056766749362498\n",
      "Total number of random sets: 1300, GR_stat: 1.0057291336966163\n",
      "Total number of random sets: 1400, GR_stat: 1.004271972561659\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 40%|█████████████████████████████████████████▏                                                             | 40/100 [27:59<46:55, 46.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0047180104493543\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 41%|██████████████████████████████████████████▏                                                            | 41/100 [28:33<42:19, 43.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0093354955782572\n",
      "Total number of random sets: 1000, GR_stat: 1.0057356230951604\n",
      "Total number of random sets: 1100, GR_stat: 1.0037797386575058\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 42%|███████████████████████████████████████████▎                                                           | 42/100 [29:07<38:58, 40.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0093877682492611\n",
      "Total number of random sets: 1100, GR_stat: 1.0078933102781082\n",
      "Total number of random sets: 1200, GR_stat: 1.0056420169113818\n",
      "Total number of random sets: 1300, GR_stat: 1.0087574342952057\n",
      "Total number of random sets: 1400, GR_stat: 1.0044338381826694\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 43%|████████████████████████████████████████████▎                                                          | 43/100 [29:50<39:06, 41.17s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0119841227859199\n",
      "Total number of random sets: 1000, GR_stat: 1.0078779354648038\n",
      "Total number of random sets: 1100, GR_stat: 1.0076607955284196\n",
      "Total number of random sets: 1200, GR_stat: 1.0049612683811946\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 44%|█████████████████████████████████████████████▎                                                         | 44/100 [30:27<37:16, 39.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0052811585536783\n",
      "Total number of random sets: 1200, GR_stat: 1.0039163812595493\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 45%|██████████████████████████████████████████████▎                                                        | 45/100 [31:04<35:50, 39.10s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0086039679311227\n",
      "Total number of random sets: 1300, GR_stat: 1.0049826543686051\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 46%|███████████████████████████████████████████████▍                                                       | 46/100 [31:44<35:28, 39.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0058390505084347\n",
      "Total number of random sets: 1200, GR_stat: 1.007552809102338\n",
      "Total number of random sets: 1300, GR_stat: 1.0065631899146075\n",
      "Total number of random sets: 1400, GR_stat: 1.0057478686512473\n",
      "Total number of random sets: 1600, GR_stat: 1.0052168053300816\n",
      "Total number of random sets: 1700, GR_stat: 1.0051266134562757\n",
      "Total number of random sets: 1800, GR_stat: 1.004773957972231\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 1900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 47%|████████████████████████████████████████████████▍                                                      | 47/100 [32:40<39:02, 44.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.004719196279967\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 48%|█████████████████████████████████████████████████▍                                                     | 48/100 [33:11<34:54, 40.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1200, GR_stat: 1.0052060198051977\n",
      "Total number of random sets: 1400, GR_stat: 1.0057772796979327\n",
      "Total number of random sets: 1500, GR_stat: 1.0061369238465345\n",
      "Total number of random sets: 1600, GR_stat: 1.0045724291319682\n",
      "MCI score: 9000, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 49%|██████████████████████████████████████████████████▍                                                    | 49/100 [34:00<36:31, 42.98s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0046416597074337\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 50%|███████████████████████████████████████████████████▌                                                   | 50/100 [34:25<31:20, 37.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0096101506353625\n",
      "Total number of random sets: 1200, GR_stat: 1.01047285422517\n",
      "Total number of random sets: 1300, GR_stat: 1.0036472446775884\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 51%|████████████████████████████████████████████████████▌                                                  | 51/100 [35:05<31:20, 38.38s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.008657591160281\n",
      "Total number of random sets: 1200, GR_stat: 1.0049326957331912\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 52%|█████████████████████████████████████████████████████▌                                                 | 52/100 [35:43<30:26, 38.05s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.00735866381231\n",
      "Total number of random sets: 1100, GR_stat: 1.0056540922312776\n",
      "Total number of random sets: 1300, GR_stat: 1.0046762850536175\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 53%|██████████████████████████████████████████████████████▌                                                | 53/100 [36:23<30:18, 38.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0072291928884278\n",
      "Total number of random sets: 1200, GR_stat: 1.0070321067001857\n",
      "Total number of random sets: 1300, GR_stat: 1.0042779292195365\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 54%|███████████████████████████████████████████████████████▌                                               | 54/100 [37:03<30:01, 39.16s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0064163971218505\n",
      "Total number of random sets: 1300, GR_stat: 1.0102742723463514\n",
      "Total number of random sets: 1400, GR_stat: 1.0073444276212393\n",
      "Total number of random sets: 1600, GR_stat: 1.0042484020473819\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 55%|████████████████████████████████████████████████████████▋                                              | 55/100 [37:52<31:38, 42.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0090263173777572\n",
      "Total number of random sets: 1100, GR_stat: 1.0115498890663757\n",
      "Total number of random sets: 1200, GR_stat: 1.0071741949012616\n",
      "Total number of random sets: 1300, GR_stat: 1.0060213703485126\n",
      "Total number of random sets: 1500, GR_stat: 1.0057906183597156\n",
      "Total number of random sets: 1600, GR_stat: 1.0054017748844102\n",
      "Total number of random sets: 1700, GR_stat: 1.0026156612563062\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 56%|█████████████████████████████████████████████████████████▋                                             | 56/100 [38:45<33:10, 45.23s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.0133915160200955\n",
      "Total number of random sets: 900, GR_stat: 1.0071733464921147\n",
      "Total number of random sets: 1000, GR_stat: 1.0051084601629667\n",
      "Total number of random sets: 1100, GR_stat: 1.0064551303200007\n",
      "Total number of random sets: 1200, GR_stat: 1.007783906431058\n",
      "Total number of random sets: 1500, GR_stat: 1.005854915686357\n",
      "Total number of random sets: 1600, GR_stat: 1.0040790882074044\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 57%|██████████████████████████████████████████████████████████▋                                            | 57/100 [39:34<33:19, 46.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0061673629270314\n",
      "Total number of random sets: 1000, GR_stat: 1.0043262714023382\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 58%|███████████████████████████████████████████████████████████▋                                           | 58/100 [40:05<29:21, 41.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0066947476340913\n",
      "Total number of random sets: 1200, GR_stat: 1.0072992661876883\n",
      "Total number of random sets: 1300, GR_stat: 1.00569485941703\n",
      "Total number of random sets: 1400, GR_stat: 1.004795997530395\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 59%|████████████████████████████████████████████████████████████▊                                          | 59/100 [40:49<28:57, 42.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0113860092661386\n",
      "Total number of random sets: 1100, GR_stat: 1.007015312858583\n",
      "Total number of random sets: 1200, GR_stat: 1.0054776590358454\n",
      "Total number of random sets: 1500, GR_stat: 1.0052739261035402\n",
      "Total number of random sets: 1600, GR_stat: 1.0068566893693098\n",
      "Total number of random sets: 1700, GR_stat: 1.0042492206492943\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 60%|█████████████████████████████████████████████████████████████▊                                         | 60/100 [41:41<30:16, 45.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0058054534250649\n",
      "Total number of random sets: 1200, GR_stat: 1.0054766652538298\n",
      "Total number of random sets: 1500, GR_stat: 1.0049856944662445\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 61%|██████████████████████████████████████████████████████████████▊                                        | 61/100 [42:28<29:42, 45.71s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.006502178554916\n",
      "Total number of random sets: 1300, GR_stat: 1.0048814451445818\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 62%|███████████████████████████████████████████████████████████████▊                                       | 62/100 [43:08<27:55, 44.09s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0065375264400336\n",
      "Total number of random sets: 1200, GR_stat: 1.0049924583183198\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 63%|████████████████████████████████████████████████████████████████▉                                      | 63/100 [43:46<25:58, 42.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.007553211852076\n",
      "Total number of random sets: 1100, GR_stat: 1.0064395810849676\n",
      "Total number of random sets: 1200, GR_stat: 1.0050029398751665\n",
      "Total number of random sets: 1300, GR_stat: 1.0050705172049612\n",
      "Total number of random sets: 1500, GR_stat: 1.0034823195882487\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 64%|█████████████████████████████████████████████████████████████████▉                                     | 64/100 [44:32<26:03, 43.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.007730949217636\n",
      "Total number of random sets: 1000, GR_stat: 1.0063519620489718\n",
      "Total number of random sets: 1100, GR_stat: 1.004456852689392\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 65%|██████████████████████████████████████████████████████████████████▉                                    | 65/100 [45:06<23:43, 40.67s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.005592433637502\n",
      "Total number of random sets: 1200, GR_stat: 1.006222416088397\n",
      "Total number of random sets: 1300, GR_stat: 1.0052922688258976\n",
      "Total number of random sets: 1400, GR_stat: 1.0047093090122443\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 66%|███████████████████████████████████████████████████████████████████▉                                   | 66/100 [45:50<23:31, 41.50s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0074490555635232\n",
      "Total number of random sets: 1100, GR_stat: 1.0078441086691958\n",
      "Total number of random sets: 1500, GR_stat: 1.0050119115482898\n",
      "Total number of random sets: 1600, GR_stat: 1.0040638329573524\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 67%|█████████████████████████████████████████████████████████████████████                                  | 67/100 [46:39<24:08, 43.88s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.009253277399912\n",
      "Total number of random sets: 1000, GR_stat: 1.0064589204754237\n",
      "Total number of random sets: 1100, GR_stat: 1.008127336535541\n",
      "Total number of random sets: 1500, GR_stat: 1.00456827739429\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 68%|██████████████████████████████████████████████████████████████████████                                 | 68/100 [47:26<23:48, 44.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0106189567104737\n",
      "Total number of random sets: 900, GR_stat: 1.0081206826274838\n",
      "Total number of random sets: 1300, GR_stat: 1.00778083199144\n",
      "Total number of random sets: 1400, GR_stat: 1.0040154209747498\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 69%|███████████████████████████████████████████████████████████████████████                                | 69/100 [48:09<22:49, 44.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.0129285700167243\n",
      "Total number of random sets: 900, GR_stat: 1.006648420080034\n",
      "Total number of random sets: 1200, GR_stat: 1.0061191230100834\n",
      "Total number of random sets: 1400, GR_stat: 1.004117603183246\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 70%|████████████████████████████████████████████████████████████████████████                               | 70/100 [48:52<21:57, 43.93s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0092645549148556\n",
      "Total number of random sets: 900, GR_stat: 1.006312059698942\n",
      "Total number of random sets: 1000, GR_stat: 1.0075804890298656\n",
      "Total number of random sets: 1100, GR_stat: 1.0071701947224954\n",
      "Total number of random sets: 1200, GR_stat: 1.0038785945900799\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 71%|█████████████████████████████████████████████████████████████████████████▏                             | 71/100 [49:29<20:17, 41.97s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1200, GR_stat: 1.005627606085784\n",
      "Total number of random sets: 1500, GR_stat: 1.0049010054893257\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 72%|██████████████████████████████████████████████████████████████████████████▏                            | 72/100 [50:16<20:11, 43.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0059889767950503\n",
      "Total number of random sets: 1200, GR_stat: 1.0075443392217758\n",
      "Total number of random sets: 1400, GR_stat: 1.0049653445939186\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 73%|███████████████████████████████████████████████████████████████████████████▏                           | 73/100 [50:59<19:28, 43.27s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0062206935622553\n",
      "Total number of random sets: 1100, GR_stat: 1.0093634734968469\n",
      "Total number of random sets: 1300, GR_stat: 1.007748074470051\n",
      "Total number of random sets: 1400, GR_stat: 1.0035260841122822\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1500 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 74%|████████████████████████████████████████████████████████████████████████████▏                          | 74/100 [51:42<18:46, 43.32s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0099217474374167\n",
      "Total number of random sets: 900, GR_stat: 1.007667731612657\n",
      "Total number of random sets: 1000, GR_stat: 1.0070472616985249\n",
      "Total number of random sets: 1200, GR_stat: 1.0052387380406655\n",
      "Total number of random sets: 1300, GR_stat: 1.007744695014633\n",
      "Total number of random sets: 1400, GR_stat: 1.0068291654887298\n",
      "Total number of random sets: 1500, GR_stat: 1.0068628465686382\n",
      "Total number of random sets: 1600, GR_stat: 1.0048415028312365\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 75%|█████████████████████████████████████████████████████████████████████████████▎                         | 75/100 [52:34<19:02, 45.68s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0086816803265486\n",
      "Total number of random sets: 1200, GR_stat: 1.0047161905491506\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1300 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 76%|██████████████████████████████████████████████████████████████████████████████▎                        | 76/100 [53:11<17:14, 43.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0062915674952215\n",
      "Total number of random sets: 1100, GR_stat: 1.0046757228124272\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 77%|███████████████████████████████████████████████████████████████████████████████▎                       | 77/100 [53:45<15:29, 40.43s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0109278217450002\n",
      "Total number of random sets: 1200, GR_stat: 1.0056035334481297\n",
      "Total number of random sets: 1300, GR_stat: 1.0080254325631723\n",
      "Total number of random sets: 1400, GR_stat: 1.005246513333484\n",
      "Total number of random sets: 1500, GR_stat: 1.0057769449039415\n",
      "Total number of random sets: 1700, GR_stat: 1.005861769681616\n",
      "Total number of random sets: 1800, GR_stat: 1.0039047333058941\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 78%|████████████████████████████████████████████████████████████████████████████████▎                      | 78/100 [54:41<16:30, 45.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0069728499463206\n",
      "Total number of random sets: 900, GR_stat: 1.0124981423911867\n",
      "Total number of random sets: 1000, GR_stat: 1.0048831200538573\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 79%|█████████████████████████████████████████████████████████████████████████████████▎                     | 79/100 [55:12<14:21, 41.04s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0077169569495903\n",
      "Total number of random sets: 1300, GR_stat: 1.004594481509893\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 80%|██████████████████████████████████████████████████████████████████████████████████▍                    | 80/100 [55:55<13:52, 41.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.007426740552583\n",
      "Total number of random sets: 1200, GR_stat: 1.007028402273243\n",
      "Total number of random sets: 1300, GR_stat: 1.0054646295649967\n",
      "Total number of random sets: 1500, GR_stat: 1.0064772376365259\n",
      "Total number of random sets: 1600, GR_stat: 1.0086337232168614\n",
      "Total number of random sets: 1700, GR_stat: 1.0038170852222257\n",
      "MCI score: 8998, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 81%|███████████████████████████████████████████████████████████████████████████████████▍                   | 81/100 [56:49<14:21, 45.34s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0042188340160343\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 82%|████████████████████████████████████████████████████████████████████████████████████▍                  | 82/100 [57:15<11:46, 39.25s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0123566905978847\n",
      "Total number of random sets: 1000, GR_stat: 1.0081329039145295\n",
      "Total number of random sets: 1100, GR_stat: 1.0081566756795035\n",
      "Total number of random sets: 1200, GR_stat: 1.0065234268085084\n",
      "Total number of random sets: 1400, GR_stat: 1.0080306989372314\n",
      "Total number of random sets: 1500, GR_stat: 1.0060851442338952\n",
      "Total number of random sets: 1600, GR_stat: 1.0069485672234872\n",
      "Total number of random sets: 1700, GR_stat: 1.0044053592613222\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 83%|█████████████████████████████████████████████████████████████████████████████████████▍                 | 83/100 [58:07<12:13, 43.15s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.0064812472767513\n",
      "Total number of random sets: 1100, GR_stat: 1.0039334374285775\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 84%|██████████████████████████████████████████████████████████████████████████████████████▌                | 84/100 [58:41<10:46, 40.40s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0099375444442142\n",
      "Total number of random sets: 1200, GR_stat: 1.006101127988267\n",
      "Total number of random sets: 1300, GR_stat: 1.003529292012474\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 85%|███████████████████████████████████████████████████████████████████████████████████████▌               | 85/100 [59:21<10:04, 40.28s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0072337344213786\n",
      "Total number of random sets: 1100, GR_stat: 1.005425128313375\n",
      "Total number of random sets: 1300, GR_stat: 1.0043207605356668\n",
      "MCI score: 8997, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 86%|██████████████████████████████████████████████████████████████████████████████████████▊              | 86/100 [1:00:01<09:23, 40.24s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.0097635031198569\n",
      "Total number of random sets: 900, GR_stat: 1.0098278126897218\n",
      "Total number of random sets: 1100, GR_stat: 1.0124528689587509\n",
      "Total number of random sets: 1300, GR_stat: 1.0078936573474735\n",
      "Total number of random sets: 1400, GR_stat: 1.005576359394826\n",
      "Total number of random sets: 1500, GR_stat: 1.0049779164628057\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 87%|███████████████████████████████████████████████████████████████████████████████████████▊             | 87/100 [1:00:47<09:05, 42.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0135979081733928\n",
      "Total number of random sets: 1100, GR_stat: 1.0120985783494052\n",
      "Total number of random sets: 1200, GR_stat: 1.0050515891209142\n",
      "Total number of random sets: 1400, GR_stat: 1.0076689946378454\n",
      "Total number of random sets: 1600, GR_stat: 1.00369047020329\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 88%|████████████████████████████████████████████████████████████████████████████████████████▉            | 88/100 [1:01:36<08:50, 44.19s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1300, GR_stat: 1.0052989256177236\n",
      "Total number of random sets: 1400, GR_stat: 1.007353165169779\n",
      "Total number of random sets: 1500, GR_stat: 1.0046979717868871\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1600 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 89%|█████████████████████████████████████████████████████████████████████████████████████████▉           | 89/100 [1:02:23<08:13, 44.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0047064046707457\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 90%|██████████████████████████████████████████████████████████████████████████████████████████▉          | 90/100 [1:02:54<06:47, 40.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 700, GR_stat: 1.0109948790004202\n",
      "Total number of random sets: 1100, GR_stat: 1.0067111229580061\n",
      "Total number of random sets: 1300, GR_stat: 1.0081501055203057\n",
      "Total number of random sets: 1400, GR_stat: 1.0067147277190087\n",
      "Total number of random sets: 1500, GR_stat: 1.0060326861741458\n",
      "Total number of random sets: 1600, GR_stat: 1.0066356078152374\n",
      "Total number of random sets: 1700, GR_stat: 1.0061501537876119\n",
      "Total number of random sets: 1800, GR_stat: 1.0037593134606078\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 91%|███████████████████████████████████████████████████████████████████████████████████████████▉         | 91/100 [1:03:49<06:46, 45.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1000, GR_stat: 1.0047173068179414\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1100 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 92%|████████████████████████████████████████████████████████████████████████████████████████████▉        | 92/100 [1:04:21<05:28, 41.03s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0092875776909251\n",
      "Total number of random sets: 1000, GR_stat: 1.0103462415477709\n",
      "Total number of random sets: 1100, GR_stat: 1.0101985708754728\n",
      "Total number of random sets: 1400, GR_stat: 1.0068364861120542\n",
      "Total number of random sets: 1500, GR_stat: 1.0074781074589774\n",
      "Total number of random sets: 1600, GR_stat: 1.004818440073797\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1700 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 93%|█████████████████████████████████████████████████████████████████████████████████████████████▉       | 93/100 [1:05:10<05:04, 43.46s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0071662611056678\n",
      "Total number of random sets: 1200, GR_stat: 1.0086900316445475\n",
      "Total number of random sets: 1300, GR_stat: 1.0043670688813946\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 94%|██████████████████████████████████████████████████████████████████████████████████████████████▉      | 94/100 [1:05:50<04:14, 42.45s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.003973060542146\n",
      "MCI score: 8993, Therehosld: 8991\n",
      "We have seen 1200 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 95%|███████████████████████████████████████████████████████████████████████████████████████████████▉     | 95/100 [1:06:24<03:19, 39.92s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 800, GR_stat: 1.008444849280543\n",
      "Total number of random sets: 900, GR_stat: 1.0064157232148465\n",
      "Total number of random sets: 1100, GR_stat: 1.0056869199182892\n",
      "Total number of random sets: 1200, GR_stat: 1.0051277303063528\n",
      "Total number of random sets: 1300, GR_stat: 1.0048373893958606\n",
      "MCI score: 8996, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 96%|████████████████████████████████████████████████████████████████████████████████████████████████▉    | 96/100 [1:07:04<02:39, 39.94s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.0092205575963789\n",
      "Total number of random sets: 1300, GR_stat: 1.0055889929043607\n",
      "Total number of random sets: 1400, GR_stat: 1.0064588035792439\n",
      "Total number of random sets: 1500, GR_stat: 1.0078000650767975\n",
      "Total number of random sets: 1600, GR_stat: 1.006022106626694\n",
      "Total number of random sets: 1700, GR_stat: 1.0039132931690509\n",
      "MCI score: 8995, Therehosld: 8991\n",
      "We have seen 1800 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 97%|█████████████████████████████████████████████████████████████████████████████████████████████████▉   | 97/100 [1:07:56<02:10, 43.62s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1200, GR_stat: 1.0054921566102148\n",
      "Total number of random sets: 1400, GR_stat: 1.006068744292803\n",
      "Total number of random sets: 1500, GR_stat: 1.0061993194888494\n",
      "Total number of random sets: 1800, GR_stat: 1.0031908617613696\n",
      "MCI score: 8992, Therehosld: 8991\n",
      "We have seen 1900 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 98%|██████████████████████████████████████████████████████████████████████████████████████████████████▉  | 98/100 [1:08:51<01:34, 47.02s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 900, GR_stat: 1.0094353168998114\n",
      "Total number of random sets: 1000, GR_stat: 1.0094563759682555\n",
      "Total number of random sets: 1100, GR_stat: 1.0071679777960783\n",
      "Total number of random sets: 1300, GR_stat: 1.005408399269477\n",
      "Total number of random sets: 1400, GR_stat: 1.0050230627132186\n",
      "Total number of random sets: 1500, GR_stat: 1.0062869348950185\n",
      "Total number of random sets: 1600, GR_stat: 1.0050973762921742\n",
      "Total number of random sets: 1700, GR_stat: 1.0052930544017793\n",
      "Total number of random sets: 1800, GR_stat: 1.0058168302006578\n",
      "Total number of random sets: 1900, GR_stat: 1.0033974776564611\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 2000 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\r",
      " 99%|███████████████████████████████████████████████████████████████████████████████████████████████████▉ | 99/100 [1:09:49<00:50, 50.39s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total number of random sets: 1100, GR_stat: 1.008063505728588\n",
      "Total number of random sets: 1300, GR_stat: 1.0047621261691417\n",
      "MCI score: 8994, Therehosld: 8991\n",
      "We have seen 1400 random subsets for each feature.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████████████████████████████████████████| 100/100 [1:10:29<00:00, 42.30s/it]\n"
     ]
    }
   ],
   "source": [
    "if not os.path.exists('fraud_example.pickle'):\n",
    "    # Train a surrogate model and generate a coalition function\n",
    "    # To efficiently estimate a conditional coalition function, we train a surrogate model. \n",
    "    conditional_extension=train.generate_coalition_function(model_to_explain, X_train, X_est, problem, ML_model)\n",
    "    \n",
    "    # With a surrogate model, we compute conditional expectations\n",
    "    exp_dict=weightedSHAPEngine.run_attribution_core(problem, ML_model,\n",
    "                                                     model_to_explain, conditional_extension,\n",
    "                                                     X_train, y_train,\n",
    "                                                     X_val, y_val, \n",
    "                                                     X_test, y_test)\n",
    "\n",
    "    with open('fraud_example.pickle', 'wb') as handle:\n",
    "        pickle.dump(exp_dict, handle, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "else:\n",
    "    with open('fraud_example.pickle', 'rb') as handle:\n",
    "        exp_dict = pickle.load(handle)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aea55d5e",
   "metadata": {},
   "source": [
    "## WeightedSHAP and Prediction recovery error curve \n",
    " - We obtain weightedSHAP (Equation (6) of the paper)\n",
    " \\begin{align*}\n",
    "    \\phi_{\\mathrm{WeightedSHAP}}(\\mathcal{T}, \\mathcal{W}) := \\phi_{\\mathbf{w}^* (\\mathcal{T}, \\mathcal{W})},\n",
    " \\end{align*} \n",
    " where $\\mathbf{w}^* (\\mathcal{T}, \\mathcal{W}) := \\mathrm{argmax}_{\\mathbf{w} \\in \\mathcal{W}} \\mathcal{T} (\\phi_{\\mathbf{w}})$.\n",
    " - A default implementation for $\\mathcal{T}$ includes the negative area under the prediction recovery error curve (AUP, Equation (4) of the paper) with `cond_pred_keep_absolute`. Note that `exp_dict` contains `remove_abolute` and `masking` as well."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "152c3f55",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_test=np.array(exp_dict['true_list'])\n",
    "pred_list=np.array(exp_dict['pred_list'])\n",
    "cond_pred_keep_absolute=np.array(exp_dict['cond_pred_keep_absolute'])\n",
    "# Find a optimal weight and construct WeightedSHAP\n",
    "optimal_ind_keep_absolute_list=find_optimal_list(cond_pred_keep_absolute, pred_list) \n",
    "\n",
    "# {13:MCI, 6:SHAP}\n",
    "cond_pred_keep_absolute_short=np.array((cond_pred_keep_absolute[:,13,:],\n",
    "                                    cond_pred_keep_absolute[:,6,:],\n",
    "                                    cond_pred_keep_absolute[np.arange(len(optimal_ind_keep_absolute_list)),\n",
    "                                                            optimal_ind_keep_absolute_list,:])).transpose((1,0,2))\n",
    "recovery_curve_keep_absolute=np.mean(np.abs(cond_pred_keep_absolute_short - pred_list.reshape(-1,1,1)), axis=0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4e4599f2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, '$|f(x)-\\\\mathbb{E}[f(X) \\\\mid X_S = x_S]|$')"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaMAAAEvCAYAAADo565XAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABj5UlEQVR4nO2deXhV1fWw35WBJIwJhHmeBBxREHACHECr1rnWOmFr1Vat1lbtYAdbP9s6trXtT0VFwFLHOs9WRXAWVESZZAYZA4QpkOmu7491bnJzuUlukpvcDOt9nv0kZ5+991lnuGedvffaa4mq4jiO4zjJJCXZAjiO4ziOKyPHcRwn6bgychzHcZKOKyPHcRwn6bgychzHcZKOKyPHcRwn6bQIZSQiN4uIRqR1IvJfERlYj8c8NThWv2C7X7B9ag3aOFdELomRP1NEnkqctI7TNIj4HYXTbhFZJiIzROSYWrY5UUR+mmBRa3L8/YJ3VHYd2vidiHwjIiERmZo46Woly5zayNAilFHAduCIIF0PDAfeFJE2DXT89cGx361BnXOBS2LkXwn8KgEyOU5T5Xrs93QycAvQCZglIr+vRVsTgZ8mTrQasx/weyC7NpVFZCTwB+CfwFHY9WhypCVbgAakRFU/DP7/UERWA7Oxh/nJ6MIikqWqexJ1cFUtBD6stmB8bS1IRDu1JdHXJpkk41wqO2ZdZGlM59FALI74Pb8DTBWRPwI3i8g7qjozSXIlg6HB33+p6o7KCjX6362qNvsE3AzkReVlAQrcEGyvBO4CfgusBYqD/BTgl8BSoBBYAkyKakuCY2wCdgLTgfOD9vsFZfoF26dG1b0MmA/sBTYCTwEdgKlB+ch0c1BnJvBUVDvHAR9FtPN/QNuI/eODNsZjyncXsBy4Mo7rV+trE5Q7E/gY2ANsAV4G+sYjO9AG2B1LTmAO8EjEdh/gMWArUAC8BgyJ2B++BxcE9ygf+B9wR3AtJKr97wNFQG4V16YjcH8g917gfWB0VBkFfgb8DdgMLK0mPxeYFlyrguB+j4znnlQhZ8znrIrnKfy8HFjNtZsGfBzjeFcH9zt8H+N6VuJ4FsNynBpjXyrwDfBYRN4pwBvYb3MH9kE4MerdEP07mxrsOwJ4HliHPYOfAxdEHTMbeDAosxdYDTwQVeZA4CXs3bAT+/11i7rOkWllDa7H1Bj1x0e0e2JwDruAh4I6Pwc+wUaLNgIvAINiPF93RuVdErTZNurc3gvOfSFwGva7nFrje1vTCk0xEVsZDQsu7EURF3998AM7DTgryP9XcCNvBE4AbgNKI38MwLVACPh/wc2/H3tBVKmMgN8E9f4JnAScBTwE9AQGAm8BnwJjgtQrqDeTiJcHsD/20nwJ+/H9CHtZvBpRJvxwfh0cdwIwJcgbVc31q8u1uSg4xqPAt4P6fyN4ucYp++PAO1EyDYi8nphSWA18hg1vnooNia4BsqLuwfpA9gmYIhwS5I+POsY7wH+ruC4Zwf1ZDlwc3MPnsBdOt4hy4WM+HpQ5uZr8d4ENmDL8NjAraHNQdfekEjkrfc5iPU9Rz0u0Moq+dt8K8gdE1Z9FxWe02mclzt9yWI6Y9YBHiHiZY0rxGux3OQG4OzjuUcH+XsCM4LzCv7OBwb7zgF9goyfHYYq/CPheRPtTgEXAd4FxwIXA5Ij9g7CX/pvAGcDZwAJMGQjQHlMOin20jQEOjXp2bq7iegzEhuUUODao3z7i/q0N9h8HHBnU+SswKShzGvZxuJHg4yTi+apSGWEf9N8A84Jn6gLst7AJV0ZVKyNsWDING6N9G/tS6h71486MepBC7NsTmg58Evyfin0V3RtV5g2qUEbYF1UBcHcVcj8FzIyRP5OKP/THMCWTGpF3bnC8I4Lt8MP5x4gy6dgX+V+quX61vTYpwcP6dBVtxyP7mdgLpEdEmV9hPaBWwfYtWE+iY0SZHOxFcFXUPXgmhhzvAtMitgcE51fpyxK4FHs5DY7ISwOWAXdE5CnwWYz6++RjykKBcRF5bYL7dH9V96QSGeN5zio8T1HPS7QyeiaqXBr22/plRF7P4NqdE++zEm+iemX0Z2BPJftSAnlfA6ZE5N9JNb0RTHGkYR+ab0Xkfwn8pIp6jwCLw89pkDc4eJ5PCbZPJeJdEVW/BPhdNbJdwr49lvD9+2s1dVMxpbITuDjq+apOGV0JFBN8JAd5RxHRu6xJakkGDJ2wC1eMPRwDgO+q6vqIMm+q6t6I7eOxH9EzIpIWTthXznARSQV6A92xL+JInq5GniOwh+Dh2p5QBKOwl0RpRN5/sQf56Kiyr4f/UdViTBH0iuMYtbk2Q4AeVH2O8cj+CvZV/Z2IMt8N6hUF2ydgHwA7ImTZCcwFRkYd86UYcjwEnC0ibYPtS7CvxVerkP2EoP0VEccE61HFc8xY+aOAzar6TjhDVXcDL7LvvYy+J7FI5HMGUfKqagn2rH83Ivs72LBWuGw8z0qikAobIr1EZJqIfIM9U8WYwcJ+1TYkkiMi94jIKsrfHZdH1f0cuEFErhSRWG2eADwDhCLOewX2so9+RvZBVdNU9Y/VlauCfZ47ERkjIm+IyBbsmhQAbYnjmkQxCpirqmsj5H0P6xnVmJakjLYDh2MPQC/sK+SVqDIbo7ZzsS+H7ZQ/jMXYOG0apoS6BWWjb0B1N6RT8Hd9laXioztRsgcv9y3Y8FUk+VHbRUBmHMeozbWJ5xyrlT144T5H8MITkSHAIVivKlKe70bJUowNXfSu5lwAnsBemOeKiGDDbtODl21l5GLDItHH/H6cx4yVv8/1iCgXfS8razOSRD5nlR3zMUyphF9m3wWe1/LJ8nielUTRMyyjiKRg8yVHAr/DnoXDsY+beJ75qdi53IEpsMOxYbnIulcDzwbtLxaRr0XkvIj9udhQX/QzMoB9n5H6oML9EpE+2AepAFdgPZnDsfdVPNckkm7Efs/VShm1NGu6OdWU0ajtrdiXw1HYiyqaTZRfwy5R+6K3o9kS/O2ODXPUhfXRxwu+Njth55AIanNt2gX/V/WyiVf2x4EXgh/Td7Fhq7ei5Hme2GatO6O2o88FVd0tIo9hPaJVQF/sZVQVW7HJ2h/H2FdY3TEryd/negR0Zd97WVmbkcTznO0FWkXlRSu+qo45E5vj+q6ITAdGY8NlYeJ5VupM0Os4DpuvAhsePBT4lqq+GlEuK462MrE5zKtV9b6I/Aof8Kqaj81JXSMiB2NzYjNE5As1q9etWM/owRiHqevvPh6i79dJQGvg9KDHHb5u0fc7nmdiA+WWfJFU9+6LSUtSRrXhLeyLroOqvhGrgIiswW7K6VQc0jmrmrY/wKyNJmFrJmIRb6/lI+BMEfl1xHDXWdj9rcm6ppoQz7VZjM0ZTcIsdmIRr+yvA9uw+aTvYnMckUN7bwb7vtLam68+hFlb3Qx8qKoLqyn/JvbFvFpVE/JCxa7HH0RkrKrOAhCR1tiL8ZlatBfPc7YWGBuVNyHeA6hqKFiE/V3sJbaDir+Fap+VBPE7bFg4rDzCSqfsw0BE+mJK8YuIerF+ZxmYzJF122ET/jE/AlT1CxG5AZvIH4oZKryJWZzN1WBSJQbhoeaa9kxqQxb2QRDZ4z+XfXXBWszIK5LoZ+IT4AIR6RUeqhORo3BllHhUdbGI3Ac8JiK3Y1/BmcABwH6q+kNVLQ323SkiedjapbPZ90ZGt50vIrcAt4pIK8yiJQN76fxBVb/BrHROF5EzsIdjnaqui9Hc/8OsyJ4VkXuxYcjbgNdU9YM6XobK5I/n2oREJPylOAOzqFPs6/XRoKcal+yqWiwiz2Cm0N2xydNI7sYsmd4SkX9gSrArZuH0rqo+Gsc5fSQiX2FzM1fEcRmmY9Z/M0XkTsySqBM2lr5BVf8aRxvRMrwmIu8Bj4vIL7GezfXYS+SOWrQXz3P2DHCpiPwVm2M4FrM+qwmPY0NW11FxLi+uZwUg8DbyMNBfVVdWc7whwe+tFdAfs3w7CbM8C8+3LcJ+N3eJyG+xnvofsGcjkkVA1+D4X2KWtytF5BPgdyKyA3uB/xIbamwfrigi72LX70vs2b4Mmy/7OChyc/D/SyIyBesN9cRe7FPV1kMtDspeEfTOC1R1ftB+CWZ0VJd5o0jCHwYPi8hD2D24nn2H758B/iEiv8aUzllB2Ugexiw1XxKRm7Fn9BZq2+OrqcVDU0zEMO2OUWYlUdYjWm5F81PgK+wraTM2QX1xVJlbgn07MVPReNcZXYF9QRViPawngPbBvtzgodhK9euMjqd8rc4mKl9ndGBUvX3aSuS1CcqdhU3078Veri9RcZ1RlbJHlDshOIdvgJQY+8PGEhsDeVYC/wYOqOoeRLXx/7AJ3fZxPlsdgL9jJuRF2MvvaQLT4aCMYsM90XUry++MKbptWK/mHeDweO5JFXJW+pwF+38VnMPO4JqFewDR1nSVWbEJZlqvwIm1/B1dGezLqeI8wnKE0x7sI2AGcEyM8odTvsbta2wYdiowJ6JMZvDcbKLiOqNB2Mt7d3BuNxL1LsE+EOYH1y0fs9I9JkqGoZhl7NZAjqWYVV6kFdrPseHhEiqappf97qu4JpdQuTXdgTHKX4xZfO7BRgJGRz9PmKXt3cGzsg17xi+PcZyDsbV1hZhSPYNarjOSoEHHcQAR+Rhb3X9RsmVpaYjINCCkqt9PtixOw+PDdI5DmX+v47Av6auSLE5L5QhsiNtpgXjPyHEAEVFsmOU2Vf1LksVxnBaHKyPHcRwn6bSkRa+O4zhOI8WVkeM4jpN0XBk5SUVEbhSR8THyVUSurqdjXhK037b60o0bSUI0YKlF1OIq2ooZ5VRERgVrV5wWgisjJ9nciK2JcGpHZdGAmwqVRTkdFeQ7LQRXRo7TyAj8ojkJJB5/dE5ycWXkJA0RWYm5z/l9MOyjUUN2qSLyJxHZLCKbRORfIpIR1UYfEXlMRLaKSIGIvBZ49a6pLLlBqIEtQTszg7VH4f1/FJElEdttRKRYRD6NaiMkIhMi8o4WkXeCNreIyAOBj7Pw/vCQ4ajgmHuAG+KUeSq2LmdcxPW7OarM+SKyVER2iMgrItIran+miNwuImtEpFBE5onIyXFetvYi8oiI7Azuzz49GRE5UEReCsrsFJEnRaRbsG885T4LVwTyrwyGHf8RlAmf18x42gy3G9Q5UUSeF5FdWGBBpzFTU5cNnjwlKmEelfMxj8bhKJthV0iKuWCZivlJuwFzlXJjRP1qo7tWctxL2NetSZXRVSl3RdQ12J6AuVMpjZD5zEDGcPCxozA3KY9j0UIvwlwZPRVDlmWYj7BjiYj0Wc31qy4a8BrMVcvpmO+2jcDLUW28iLnB+THm9PXB4ByGV3HcfpS7Zbo/uD+3Yv7broooV6sop5g7pDuD/PB57R9Pm0GZ8VQS5dRT401JF8BTy06YU8WbY+QrMCsq71nMm3Z4u9rorpUcM6wAwkqj2uiqwXYx5dFL/4gFAVwHnBTk3U1E5FLMae7bUcc+joo+38KyXFvL61dVNODtRPh5w3zDKeVh2I+PPu8gfxbwZBXHDCuj16PyHyDCbyB1iHKKOV3VGMeOp82wMvprsp9vT/EnH6ZzGjOvR20voGJU2ppEd62KaqOrBtufAccERcZiL+3ZUXmzoSzswxHAE1Ixuum7mFIbESVDZZFg68InqrotYntB8Ldn8PcErDf4nuwbgTWe6/dM1PbTmLPa8D2qU5TTSqhJm/VxTZ16wpWR05jJj9qOjjtTk+iuVRFvdNVZwDFioRhGYYpndpDXFhgebIP10FIxD+SRshViHpHjjQRbF/KjtqPj5uRi0Tqjr9/NMeSLRWXRjcPBFOsjymlN2qyPa+rUE+4o1WnK1CS6a1XEG111Nhav53jsBTgPGx66Ext+S6U8IGA+gft/LIZQNNFxqZLhl2srNqx2Ri3rVxbdOBzivD6inNakTfd11oRwZeQkm3ij2cYiEdFdIf7oqu9iE++/BN5TC6w4HzNk+DmwSFU3Q1kY8w+BIZq4wGixqOv1+zmwS1UX1aL+mcC9EdtnYYpobUT7tY1yWgRm7aeqe6Nkrq5NpwniyshJNouAU0TkVWAXFkso3l5NnaO7QvzRVVV1i4gswOaGfhXkhYK6p2AT+JHcCLwpIiHM0GAn0Ccoe5OqLqEKwubMqjq+imLxRgOOxRvAa8AbInIbFviuPTbcmKmqv6qm/gEicj9myDEWuBQzxAgF+2+m9lFOw8rxWhF5C9ihqovjbNNpgvickZNsbsAiab6EmedGT+xXiqrmYWa/i4C/YgYPt2PRV7+ooRxnYi/nvwFPYj2g41R1aVS58JzQrBh570YWVNV3sZd0Z8wK7AVMQa0hvvmM1uw7LxPN/2HnPQW7fpfH0W5YPsV6M1MwS7vXMFPtI4g6l0q4EVNe/8Uiyd5CxHqeQNmOwSLnTgZewcJ+F2LRTlHVVZjiPwt4j/J1R7OxD4FrsZ7r/fG26TRNPISE4zRCgsW9O4CJkVZ+jtNc8Z6R4zRORgJfuiJyWgreM3Icx3GSjveMHMdxnKTjyshxHMdJOo3CtFtETgL+ji0afFBV/xK1X4L9J2NWNJeo6qfV1RWRn2A+rkqAl1T1xqrkyM3N1X79+iXqtBzHcVoEc+fOzVPVznVpI+nKSERSgX9h6wTWAp+IyPOquiCi2LcwZ4iDgdHYQrvRVdUVkWMxb8UHq2qhiMRaYV+Bfv36MWfOnESenuM4TrNHRFbVtY3GMEw3CliqqstVtQh4DFMikZwOTFfjQyBbRLpXU/fHwF9UtRBAVatbr+E4juMkicagjHpiiwDDrKXcq3B1Zaqqux/mwPKjILjZ4bEOLiKXi8gcEZmzefPmOpyG4ziOU1sagzKSGHnR9uaVlamqbhrmOXkMtsr/iWDuqWJh1cmqOlJVR3buXKchT8dxHKeWJH3OCOvNRLp+78W+Ho0rK9OqirprgacDlycfB/7BcrGAaY7jOE4jojEoo0+AwSLSH3N0eR5wflSZ54GrA0eKo4HtqrpeRDZXUfdZzK3/TBHZD1NctXVb7zgtklAoxNq1a9m9e3eyRXGSSHp6Ol26dKF9+/b1doykKyNVLRGRqzEnjanAFFX9SkR+FOy/D4sHczLmCLEA+H5VdYOmpwBTRORLzB39JHc57zg1Iy8vDxFhyJAhpKQ0hlF9p6FRVfbs2cM333wDUG8Kyd0BRTBy5Eh1027HKWfJkiX069ePVq1aJVsUJ8kUFBSwbt06Bg0atM8+EZmrqrUNJQ80gp5RU2fRInjlFRgwAE6PNkh3nCZOaWkp6enpyRbDaQRkZWVRXFxcb+27MqojoZAppHq8R46TVGIYoTotkPp+DnwQuI707Wt/V682xeQ4juPUHFdGdaRNG8jNtZ7R+vXJlsZxWg7huay8vIpGssOHD0dEWLlyJQAff/wxJ598MtnZ2XTs2JFRo0bx8MMPAzBz5kx69erV0KI7MXBllADCvaNVdfbO5DhOTejfvz+PPvpo2fb8+fPZs2dP2fYHH3zAcccdx7hx41i6dClbtmzh3nvv5ZVXXkmGuE4VuDJKAK6MHCc5XHTRRUyfPr1se9q0aVx88cVl2zfccAOTJk3iF7/4Bbm5uYgII0aM4IknnkiGuE4VuDJKAK6MHCc5jBkzhh07drBw4UJKS0t5/PHHufDCCwEzRf7ggw8455xzkiylEw9uTZcA+vSxv2vWQGkppKYmVx7HqS+uuKJhjnP//fGXDfeOxo0bx9ChQ+nZ03wlb9u2jVAoRPfu3etJSieRuDJKAK1bQ5cusGkTrFsHvXtXX8dxnMRw0UUXMXbsWFasWFFhiC4nJ4eUlBTWr1/P0KFDkyihEw+ujBJE376mjFatcmXkNF9q0mNpKPr27Uv//v15+eWXeeihh8ryW7duzRFHHMF///tfjj322CRK6MSDzxklCJ83cpzk8dBDD/HWW2/Rpk2bCvm33347U6dO5Y477mDLli0AzJs3j/POOy8ZYjpV4MooQbgycpzkMXDgQEaO3Nc12pFHHslbb73FW2+9xYABA+jYsSOXX345J598chKkdKrCh+kSRNiIYe1aKCmBNL+yjlOvhBe1RpOWlkakA+hRo0ZVuq5o/PjxrF27tj7Ec2qI94wSRGYmdO1q1nSBp3XHcRwnTlwZJZB+/eyvD9U5juPUDFdGCSTSaarjOI4TP66MEkhYGVUylO04juNUQrXT7CLSpy4HUNUW00/o3RtEbM6ouBg8JpnjOE58xGPztRKoTWxyCeq1GOc4GRnQrZuFkvjmm/I5JMdxHKdq4lFG/etdimZE376mjFaudGXkOI4TL9UqI1V127Aa0K8ffPihW9Q5juPUBDdgSDBuUec4yWfq1KkcffTR9dL2JZdcwm9+85t6abslE48BQ22jUN2oqitrWbfJ0qsXpKSY9+6iImjVKtkSOU7z5d133+XGG2/kq6++IjU1lWHDhvG3v/0t2WI5tSCeOaNzgM+AHXG2KcAxwF8w44cWRatW0KOHuQVauxYGDEi2RI7TPNmxYwennnoq9957L+eeey5FRUXMnj2bjIyMZIvm1IJ4h+l+rKrHxpOAEzCF1GIJ+6nzeSPHqT+WLFkCwPe+9z1SU1PJyspi4sSJHHzwwWVlrr/+enJycujfv38F/3QPP/www4YNo127dgwYMID7I2JjzJw5k169evGnP/2J3Nxc+vXrx4wZMyqV48UXX2T48OFkZ2dz5JFH8sUXXwBwxx13cPbZZ1co+5Of/ISf/vSniTj9Zkc8yugPQE08CZYGddbVSqJmQHWLX4uLIS+vwcRxnGbJfvvtR2pqKpMmTeKVV15h27ZtFfZ/9NFHDBkyhLy8PG688UYuvfTSMgeqXbp04cUXX2THjh08/PDDXHfddXz66adldTds2EBeXh7ffPMN06ZN4/LLL2fx4sX7yPDpp5/ygx/8gPvvv58tW7ZwxRVXcNppp1FYWMiFF17Iq6++Sn5+PgAlJSU8/vjjXHTRRfV3UZow8VjT/aEmDard7RrVaW5U5aNu40a45x7YuhVuuMGH8ZymxRUvNEzc8fu/XX0Uv/bt2/Puu+9y2223cdlll7FhwwZOPvlkHnjgAcCC7l122WUATJo0iSuvvJKNGzfSrVs3TjnllLJ2xo0bx8SJE5k9ezaHHXZYWf4tt9xCRkYG48aN45RTTuGJJ57gt7/9bQUZHnjgAa644gpGjx5ddpw//elPfPjhh4wbN46xY8fy5JNPctlll/Hqq6+Sm5vLiBEj6nx9miO1tqYTkQNFpF0ihWku9OxpRgwbNkBhYXn+0qVw223WKwqF4M03kyej4zQHhg0bxtSpU1m7di1ffvkl69atKxsG69atW1m51q1bA7Br1y4AXnnlFcaMGUPHjh3Jzs7m5ZdfJi9iuCInJ6dCoL6+ffuybt2+gz2rVq3irrvuIjs7uyytWbOmrOykSZP497//DcC///1v7xVVQV2i7swAvg3sFBEB7gGGAy+p6l8SIFuTJT3dFNKaNZYGDYK5c2HKFIt1NGwYLF4Mn34K27dDhw7Jlthx4iOeHkuyGDp0KJdccgn3338/J554YqXlCgsLOfvss5k+fTqnn3466enpnHHGGRViIG3bto3du3eXKaTVq1dz4IEH7tNW7969uemmm7jppptiHuuMM87gxz/+MV9++SUvvvgit99+ex3PsvlSl3VGaRF+584BzgCmAkeKyK/rKFeTJzxUt3Il/O9/MHmyKaJx4+Caa+CQQ6x3NHt2MqV0nKbLokWLuOuuu8qC461Zs4ZHH32UMWPGVFmvqKiIwsJCOnfuTFpaGq+88gqvv/76PuV+//vfl1novfjii3znO9/Zp8xll13Gfffdx0cffYSqsnv3bl566SV27twJQGZmJueccw7nn38+o0aNok+fOrn6bNbURRntifj/DOA+VX0IOA9TTi2a8DP38svw5JP2/1lnwfe+Z0N448db3qxZFpDPcZya0a5dOz766CNGjx5NmzZtGDNmDAceeCB33XVXtfXuuecezj33XHJycvjPf/7DaaedVqFMt27dyMnJoUePHlxwwQXcd999DB06dJ+2Ro4cyQMPPMDVV19NTk4OgwYNYurUqRXKTJo0ifnz5/sQXTVIZNe0RhVF7gOWAW8AM4Hxqvp5sO8zVT00QTI2GCNHjtQ5c+YkpK1Vq+BPf7L/09Lgkkvg8MPL96vCH/5gfuwuuwxGjkzIYR0noSxcuJBhw4YlW4wGZebMmVx44YUJC0e+evVqhg4dyoYNG2jfvn1C2kwWlT0PIjJXVev0FqtLz+gXwOHAO8ALEYooA2hbF6GaAz17Qvv20Lo1XHttRUUEFmoi3DuaObOhpXMcpyEIhULcfffdnHfeeU1eEdU3tTZgUNXtwLkxdh0LtHg7sbQ0+N3vIDXVFFIsxoyBp5+Gr7+2kBM9ezasjI7j1B+7d++ma9eu9O3bl1dffTXZ4jR6atQzEpG/BZZzlaKqr6rqj2rY7kkislhElorIL2PsFxG5J9j/hYgcVl1dEblZRL4Rkc+DdHJNZEoE7dpVrogAMjPhiCPsf+8dOU7jYPz48QkZomvTpg27du3iq6++onfv3gmQrHlT02G67wHPikjMV6yIfKumAohIKvAv4FvA/sD3RGT/qGLfAgYH6XLg3jjr/lVVhwfp5ZrK1hCEh+o++gj27KmyqOM4TrOlpspoDDAImC0i3cOZInKiiHwEvFgLGUYBS1V1uaoWAY8Bp0eVOR2YrsaHQHZw/HjqNmq6d4chQ2xx7AcfJFsax3Gc5FAjZaSqK4AjgTzgYxH5gYi8D7wCbAfG10KGnsCaiO21QV48Zaqre3UwrDdFRHJqIVuDEGnIUEvjRsdxnCZNja3pAsOFO4Ec4AEgEzhCVSeqam2WcMaag4p+JVdWpqq69wIDMa8Q64GYiw9E5HIRmSMiczZv3hyXwIlm+HDIyTG/dYsWJUUEx3GcpFJTA4YTReRd4FXgfeB+bK5mUB1kWAtEzu71Yl+P35WVqbSuqm5U1VJVDWFKc1Ssg6vqZFUdqaojO3fuXIfTqD0pKTB2rP3/9ttJEcFxHCep1LRn9ApQCIwLekJXAtcAU0Sktp66PwEGi0h/EWmFeXB4PqrM88DFgVXdGGC7qq6vqm7knBZwJvBlLeVrEI4+2szAv/jCPHo7jtMwzJgxg4kTJ8ZVtj7DmTdE+42Zmiqj8ap6vKq+G85Q1cnAqcA1IvJYTQVQ1RLgauA1YCHwhKp+JSI/EpGwifjLwHJgKdbLubKqukGd20Vkvoh8ga19uq6msjUk7dvDiBE2Z+SGDI5TPX/+8585+eSKKzYGDx4cM++xxyp/NV1wwQUxfdPVhvHjx/Pggw8mpC2A5557juHDh9O+fXtyc3M5/vjjWRkESrv55pu58MIL96kjIixdurRC3tSpUxERnnjiiQr5M2fOJCUlhbZt29KuXTuGDBnCww8/nDD5a0KNFr2q6qxK8t8QkaOBF2ojRGB2/XJU3n0R/ytwVbx1g/wm5wjq0EPh449h2bJkS+I4jZ+xY8fyl7/8hdLSUlJTU9mwYQPFxcV8+umnFfKWLl3K2PA4eBNi6dKlXHzxxTz99NMcd9xx7Nq1i9dff52UlJo7zpk2bRodO3Zk2rRpnHtuRV8FPXr0YO3atagqzz33HOeccw6jR49m//2jV9jUL3VxB1SBoEcyOlHttUT697e/K1a4VZ3jVMfhhx9OcXExn3/+OQCzZs3i2GOPZciQIRXyBg4cSJs2bbj00kvp3r07PXv25De/+Q2lgYfi6KGx119/nSFDhtChQweuvPJKxo0bt09vJ1Y485tuuonZs2dz9dVX07ZtW66++mrAvItPmDCBjh07MmTIkAq9ky1btnDaaafRvn17Ro0axbKIL9HPP/+c/v37c/zxxyMitGvXjrPPPrvGnr9XrVrFO++8w+TJk3nttdfYuHFjzHIiwhlnnEFOTg4LFiyo0TESQcKUEYCqJsccrZmQnW2poAA2bUq2NI7TuGnVqhWjR49m1iwbsJk1axbHHHMMRx99dIW8sWPHMmnSJNLS0li6dCmfffYZr7/+eszhtLy8PM455xz+/Oc/s2XLFoYMGcL7779foUxl4cxvvfVWjjnmGP75z3+ya9cu/vnPf7J7924mTJjA+eefz6ZNm3j00Ue58sor+eorm0246qqryMzMZP369UyZMoUpU6aUHeewww5j0aJFXHfddbz99ttlgQFryvTp0xk5ciRnn302w4YNY8aMGTHLhUIhnnnmGfLz8znooINqday6UJfgek6CEbHe0WefWe+oa9dkS+Q4UVzRMGHHuT++IH7jxo1j1qxZXHfddcyePZtrr72WHj16cP/995fl/exnP+Pyyy8nPz+frKws2rRpw3XXXcfkyZO5Iup8Xn75ZQ444ADOOussAK655hruvPPOCmWqCmcezYsvvki/fv34/ve/D5iCOfvss3nqqacYOnQo//3vf5k/fz5t2rThwAMPZNKkSWWKdMCAAcycOZO7776bc889l507d3Leeefxz3/+k7ZtzRf1E088wYsvVu1rYPr06Vx1lc1ynH/++UybNo2f/exnZfvXrVtHdnY2KSkp9OnTh0ceeYQhQ4bEdf0TSUJ7Rk7dCQ/VLV+eXDkcpykwduxY3n33XbZt28bmzZsZPHgwRx55JO+//z7btm3jyy+/ZOjQoRQXF9O9e/ey0OBXXHEFm2IMP6xbt66CHzkRoVevXhXKVBXOPJpVq1bx0UcfVQhLPmPGDDZs2MDmzZspKSmpcLy+fftWqD9mzBieeOIJNm/ezOzZs5k1axa33npr2f5zzz2X/Pz8CimS9957jxUrVnDeeecBpozmz59fNowJNmeUn5/P1q1b+fzzz8vKNjTeM2pkRM4bOU6jI84eS0NxxBFHsH37diZPnsxRRx0FQPv27enRoweTJ0+mR48e9OnTh4yMDPLy8khLq/qV17179wpOUlW1Rk5To/1I9+7dm3HjxvHGG2/sU7a0tJS0tDTWrFlTFrhv9erV+5QLc/jhh3PWWWfx5Zfxr1KZNm0aqsrw4cMr5E+fPn2fvGRT456RiKSKSKmIHBrx/2HV13TioW9fG65buxaKipItjeM0brKyshg5ciR33303xxxzTFn+0Ucfzd13383YsWPp3r07EydO5Oc//zk7duwgFAqxbNky3nnnnX3aO+WUU5g/fz7PPvssJSUl/Otf/2LDhg1xy9O1a1eWRwxrnHrqqSxZsoRHHnmE4uJiiouL+eSTT1i4cCGpqamcddZZ3HzzzRQUFLBgwQKmTZtWVvfdd9/lgQceKOvBLVq0iOeff77asOph9u7dyxNPPMHkyZP5/PPPy9I//vEPZsyYQUlJSdzn1RDUdphOKHfFU2VICadmZGRYXKNQCKr4SHIcJ2DcuHFs2rSpgkXcMcccw6ZNm8pMuqdPn05RURH7778/OTk5nHPOOaxfv36ftnJzc3nyySe58cYb6dSpEwsWLGDkyJFkZGTEJcu1117LU089RU5ODtdccw3t2rXj9ddf57HHHqNHjx5069aNX/ziFxQWFgKUGTt069aNSy65pGxuCSA7O5vnn3+egw46iLZt23LSSSdx5plncuONN8Yly7PPPktWVhYXX3wx3bp1K0uXXnoppaWljS7GUo3DjgdhG4qBkcC88P+q+mnixWtYEhl2vC78+98wezacfTbEuTDcceqFlhh2PJJQKESvXr2YMWMGxx57bLLFSTqNNey4U08MGGB/fd7IcRqe1157jfz8fAoLC/nTn/6EqsY9NObUHldGjRA3YnCc5PHBBx8wcOBAcnNzeeGFF8qGu5z6xa3pGiHdullI8m3bID/fFsI6jtMw3Hzzzdx8883JFqPF4T2jRkh48St478hxnJaBK6NGiisjx3FaEq6MGimujJzGQk0tbp3mSSgUqtf2axN2vBT4PrAi8v9EC9bSCSujlSttzZHjJIPMzEy2bNniCqkFo6oUFRXxzTff0KZNm3o7Tq0MGFR1Wqz/ncTRrh3k5kJeHqxbB1HusRynQejVqxdr165l82Z3yN+SSUtLo0OHDuTm5tbfMeqtZafO9O9vymjFCldGTnJIT0+nf7ib7jj1iM8ZNWLCi1/dg7fjOM0dV0aNGDdicBynpVBrZSQiB4pIu0QK41Skd29IS4MNG2DPnmRL4ziOU3/UpWc0A8gBEOMfIjJbRH6ZGNGctDRTSKpmVec4jtNcqYsySlPVcJCDc4AzgKnAkSLy6zrK5QS401THcVoCdVFGkQNHZwD3qepDwHmYcnISgM8bOY7TEqiLMpojIjeIyHDgFOAlAFUtwAPuJYxIZeTrDh3Haa7URRn9AjgceAd4QVU/BxCRDKBt3UVzADp1sgWwO3fCli3JlsZxHKd+qFYZicjBsfJVdbuqnquqHVT1oohdxwJvJkrAlo578HYcpyUQT8/ofRG5IN4GVfVVVf1RHWRyoggrI1/86jhOcyUeZTQNeERE7hGRSt0HiUhvEbk9caI5YcIWdbNnw8svQ3FxcuVxHMdJNNUqI1W9CpgEXAq8LSLdIveLyNEi8iSwHLiwXqRs4QwZAmPGmBJ67jm4+Wb44gs3aHAcp/kQlwGDqj4CHAl0Bz4VkeNE5GIRmYsZMAwCLgP61ZegLRkR+P734brroEcPc576r3/BP/4BGzcmWzrHcZy6IzWJUyIi+wEfAh2CrOeBv6vqzMSL1vCMHDlS58yZk2wxqqS0FN55B55/3lwEpabCiSfCaaeZ0nIcx2loRGSuqo6sSxtx9YxEZLiITAE+x9YQPRPs2gK8XxcBnJqRmgrHHQe33AJHHWWB915+GV58MdmSOY7j1J54TLvfAeZiw3TXA71U9RzgNOAsYLaIeLSdBqZdO7j4YrjySusRvfgifPhhsqVyHMepHfH0jPYAp6jqUFX9P1XdDaCqLwGjgNYE80j1KKdTCQcfDOedZ/9Pnw5LliRXHsdxnNoQjzXdSar6aiX7lgKjgbeA10TkhgTL58TB+PFw/PE2n3TvvVUbNZSWwtdfu3m44ziNizoH11PVAlU9D/gVcGtt2hCRk0RksYgsjRWCIghRcU+w/wsROawGda8XERWR+gve3gg45xw45BAoKIB77jH3QZEUF8PMmfCb38Cdd5rSctNwx3EaCwmL9KqqdwIn1rSeiKQC/wK+BewPfE9E9o8q9i1gcJAuB+6Np66I9AYmAKtp5qSkwKWXQt++Zvp9772mgPbuhddeg1/9Ch59FLZutfJffWVWeY7jOI2BSj0q1AZVfbsW1UYBS1V1OYCIPAacDiyIKHM6MF3NDv1DEckWke7Yuqaq6v4VuBF4rhZyNTkyMuCqq+DPf4Zly+Cuu2zIrqDA9vfpA9/6llngPfAAPPUUDBsGXbsmV27HcZyE9YzqQE9gTcT22iAvnjKV1hWR04BvVHVeVQcXkctFZI6IzNm8eXPtzqAR0aED/OQnkJlpjlULCmDwYLjmGvj1r+Gww2DkyHKPDlOm2DyS4zhOMkloz6iWxFqqGT2bUVmZmPki0hq4CZhY3cFVdTIwGWzRa3XlmwI9e5ry+eADGD3alFE0551nlncrV9o6pW9/u8HFdBzHKaMx9IzWAr0jtnsB6+IsU1n+QKA/ME9EVgb5n0b71WvODBwIF14YWxEBZGWZiyERU0YensJxnGTSGJTRJ8BgEekvIq2wsOXPR5V5Hrg4sKobA2xX1fWV1VXV+araRVX7qWo/TGkdpqobGuysmgD77QcnnGBzSFOmQGFhsiVyHKelUu0wXfDy71ibxlX15TjKlIjI1cBrQCowRVW/EpEfBfvvA14GTgaWAgXA96uqWxtZWyqnn26WdevWwX//C+efn2yJHMdpiVTrKFVEnsDCi9cUVdUBtZIqSTQFR6n1wdq18Kc/mSHD6afb0F1+fsXUtq15DW/rAeUdx4kiEY5Sq+0Zqeq5dTmA0/jp1cuU0NNPW7ykWOTnwyuvwHe+06CiOY7TQmgM1nROI2DCBNi1C7Ztg5wcyM4uT0VF8Le/mQeH44+HjrUatHUcx6kcV0YOYB4czj678v2HHw6ffAIvvACTJjWcXI7jtAwagzWd0wQ47TRTWB98AOvXJ1sax3GaG66MnLjo0gWOOcacq1Y2r+Q4jlNbXBk5cXPKKdCqFXz2GSxfnmxpHMdpTtRYGYnIQSJyqYjcJCK3iMh1InKKiOTUh4BO46FDBzNgAHjmGQ9B4ThO4ojLgEFEBgA/Bi4AugIhIB8oBLKxaK+hIET5g8DjqhqqB3mdJDNxooWeWLIEFiyAAw5ItkSO4zQHqu0ZiciDwFfAcOCPwKFApqp2VtVeqtoW6AJ8G5gP3A4sFJGj601qJ2m0bm1hKMB7R47jJI54hun2AkNVdYKq3qeqX6hqhaADqpqnqq+o6k+BvsDv2DcMhNNMOPZYW3+0Zg20QIcVjuPUA9UqI1W9WlVXxdugqoZU9XFVfbxuojmNlfT08pATzz3n8ZAcx6k78QzTHdwQgjhNiyOPtAixmzfDq68mWxrHcZo68QzTvS8iF9S7JE6TIiUFvvtdc6r6wgswr8p4uo7jOFUTjzKaBjwiIveISKXWdyLSW0RuT5xoTmPngAPMwaoqPPSQhaFwHMepDfHMGV0FTAIuBd6OjpYqIkeLyJPAcuDCepHSabScdJL5rSsshH/9y5ytOo7j1JS4Fr2q6iPAkUB3LHz3cSJysYjMBd4BBgGXAf3qS1CncSJijlP79oW8PLj/fjdocByn5sTtgUFV52HRVjOBN4CHgdXA8ap6qKpOVdWi+hHTacykp8OVV0L79rYY9nG3o3Qcp4bEpYxEZLiITAE+BwR4Jti1BXi/fkRzmhLZ2aaQ0tLMQ8M77yRbIsdxmhLxmHa/A8zFhumuB3qp6jnAacBZwGwR6VWvUjpNgv794aKL7P/HHoNFi5Irj+M4TYd4ekZ7gFNUdaiq/p+q7gZQ1ZeAUZhfuk9F5Lh6lNNpIowZY/7rQiEzaFiwINkSOY7TFIjHmu4kVY25rFFVlwKjgbeA10TkhgTL5zRBzjzTFsUWFcE//wmffppsiRzHaezUOZ6Rqhao6nnAr4Bb6y6S09RJSYGLL7ZwE6WlMHkyvO8zi47jVEE8c0YXiUhqdeVU9U7gxKDOIBE5JgHyOU0UEfjOd8yHnSpMmwZvvll5+dJSKChoOPkcx2lcxBPP6OfALSLyCPBUYOK9DyLSCeghIi8A47FFsk4LRgROPRWysuCJJywVFFheYaFFi1261NLy5aa0fvITGDo02ZI7jtPQiMYRkEZEvgv8BLOo2wUsBPIoD67XH+gDbAP+Ddyhqt/Uj8j1x8iRI3WOx0SoF95/H6ZPN4XTpYs5WI316LVvD7/9rf11HKdpICJzVXVkXdqotmckIh2DcBCPi8gg4HjgMKAb0AbYCMwC3gNmqmpxXQRymidHHmk9pAcegE2bbF6pXz8YNMjSgAG2b8kSePhhuOYa61k5jtMyqLZnJCKlwGhVnSMi3VR1Q8OI1vB4z6j+Wb8edu40RdSqVcV9+flwyy3m3+6ss+DEE5MhoeM4NSURPaN41xmFXxvfiMjhdTmg07Lp3h32229fRQTmxeH737f/n30Wli1rSMkcx0km8Sijr4ArRKQz5grIceqNAw+ECRNs0eyDD8Lu3cmWyHGchiAeZXQD8C1gA6DAnSLyZxH5nogcEI/Zt+PUhDPOsGG8rVvLjR4cx2nexOOBYRbQE1NIAuwFTsK8dn8B7BaRz0Vkuoj8vD6FdVoGaWlw2WWQmQmffw4zZyZbIsdx6pt44xkVq+rrmMXcDap6KGZJdzDwfeBVIBf4aT3J6bQwcnPNiwPAU0/B66/DihVQUpJcuRzHqR/iWmfUUnBrusbHjBkwa1b5dnq6eQcfNAgGDoTBgyEjI3nyOY7TQOuMHCeZfO97pngWLzZPDRs32lqkJUtsf5s2cNxxcOyx9r/jOE2TeNYZXQM8pqqb4m7U6vxHVfPiLH8S8HcgFXhQVf8StV+C/ScDBcAlqvppVXVF5BbgdCAEbArqrKtKDu8ZNX527ix3I7RwIaxZY/kZGXDMMWaJl52dVBEdp8WRiJ5RvItex6jqJ3EKlQoUAYeHFUYc5ZcAE4C1wCfA91R1QUSZkzF3RCdjISv+rqqjq6orIu1VdUdQ/xpgf1X9UVWyuDJqWqjC11/Dq6/CV19ZXmoqHHEEnHQSdO6cXPkcp6XQUMN0AvxZRLbG2WZN1yKNApaq6nIAEXkM69FEhmU7HZiupjk/FJFsEekO9KusblgRBbTBzNKdZoSILaDdbz9YtQpee81iJ737LnzyCdx0E3TtmmwpHceJh3iU0SxsCKwm35mzgJ1xlu0JrInYXov1fqor07O6uiJyK3AxsB04Nk55nCZI375w+eU2p/T449ZTevhhuPFG84PnOE7jplplpKrjAURkqqpeUg8yxOpJRfdiKitTZV1VvQm4SUR+BVwN/H6fg4tcDlwO0KdPnzhFdhorXbvCD38If/iDmYK//roN2TmO07ipyTdjx8gNEekRXUBEavMNuhboHbHdC4g2NKisTDx1Af4DnB3r4Ko6WVVHqurIzj7J0Cxo3bp8jdILL8A3TS6YieO0POoygHFfjLyna9HOJ8BgEekvIq2A84Dno8o8D1wsxhhgu6qur6quiAyOqH8asKgWsjlNlAMOMOu6khIbristTbZEjuNURV3WGcUaIquxnzpVLRGRq4HXgvpTVPUrEflRsP8+4GXMkm4pZtr9/arqBk3/RUSGYKbdq4AqLemc5sc558CCBWb+/fLLFgLdcZzGSV2UUSzrtFpZrKnqy5jCicy7L+J/Ba6Kt26QH3NYzmk5ZGbCJZfAXXeZMjrkEIieFiwqsii0H38M48bB6GjTGcdxGoSaKKNuInIbsAN4h1r0ghynodlvP/PQ8NZbNlx3003miHX3bnPA+tZbFswPzOChUyfz+OA4TsNSE2W0G/gXZiBwJPCZiPwRyAfeBj5PtHCOkwjOPBO+/BLWrTOz7/R0W4tUWGj7+/Y1x6xz58L995vCci8OjtOw1EQZ3Yit2emNrdt5G5gJZAEnAN8D9k+wfI5TZ1q1suG6O+6o6HR1//0ttPmQIebNYedO83l3//3w859bD6o5oGrDkNu3m7sk8RCZTiMk7p9b4A7oEwARaQ2MA34LZGC9pRm4MnIaKQMHmgHDiy/CiBGmhHpHLAoQsUWzt95qvu8efxwuuKBmx9ixA156yWIw9etn808HHWQ9sWRRWAj//rcpI7Ae4GGHJU8ex6mMhISQCEKSnwAcr6o/rHODScJ90zV/VKvuGaxaBbffbibhF18MRx1VfZuFhfC//5k7ovDQX5jMTHv5jxplPbBIbxCqVr6gwMq1bl39sbZsgffeg0WLbD5swoTKvZVv2gT33WfrrETseD16wO9+570jJ7E0iKPUlkSilJGqsn7XelZsW0HnNp3Zr9N+CZDOaSjefx+mTbNhuhtusF5OLEIhUwwvvGBDYAAHH2y9rpUrrTeyalV5+fbtoUMHUz579lgK//xE7DgHHGDDh/37lyuukhLrbb37rimhyJ9sRoaFz5gwAdq2Lc//4guYMsWO0bWrRc79179g2zbrAY4YkZhr5Tjgyijh1FYZ7S3Zy4ptK1i2bRnLty1n+bbl7CneU7Z/XL9xfGf/75CemsTxGqdG/Oc/8M47kJMDv/ylKYvt2y3t2GF/P/4Y1q+38v36wdlnW28lko0brdzHH1tPJZqMDMjKsvmqyIW5WVkwdKgpr08+Mes/MAU5YoQN/33wQbm38owMGD8eTjgB3n7bTNkBDj3U5ssyM22+bMYM7x05iceVUYKpjTL6cO2HTP18KtHXsVPrTvRu35svN31JSaiE3h16c/mIy+nSpksiRXbqiZISuPtuWLas6nK5uWatN2JE1S93VVNcJSU2HJeVZSnc+ykstACCCxaYgolWXL16wdFH2zxU5HDeihU2D/bll7YdHo4TMbkmTiyXq6QEfvMb7x05iceVUYKpjTJalb+K2967jT4d+jAwZyADOw5kQM4AsjOzAVi9fTWT505m8+7NZKRlcNHBF3F4z8PrQXon0WzfDrfdBlu32hBYhw7lqX176NYNDj+8fqzu8vJMMW3bBsOH22LdqpTdypWmlObPN1kvu8x6VtF478ipD1wZJZjaKKOQhigNlVY5BLeneA+PfPEIc9fNBWBs37Gce8C5CRm2W79zPau3ryYzLbNCykrPonV6a9JSmol9cpJQtbmh1CayxHvjRlNGlRk1RPaOLrsMRtbp9eE4RlKVUeD3bYGqNpGfafXUpzWdqjJr1Sye+OoJSkIl9GjXgxMGnMCIHiPITMuscXshDfHq0ld5YfELhDQUs0xmWiY/OPQHHNLtkLqK7zQjwr2j7t3h97/33pFTdxqDMlqoqs0mdFlDmHav2b6GyXMns2m3TQq0Sm3Fod0P5cjeRzKk0xAkjjdD/t58Hvr0IZZsWQLAwV0PBsyQYk/JHgpLCikoLmBX0S7SU9O5dvS1DO40uKomnRZESQn89rc2/Oi9IycRNAZl5D2jWlBUWsScdXP4YM0HZQoFoGNWR8b0GsNBXQ+iX3Y/UmKEh5q3YR7T5k1jd9Fu2me055Lhl3BAlwP2KaeqzJg/g9mrZpOVnsX1R15Pr/a96vW8nKbD7Nm2GLZ7d5s78mi4Tl1wZZRgkrHoNa8gjw/WfMAHaz9gS8GWsvyMtAwGdxzMkNwhDM0dSre23Xh64dO8veJtAA7ocgCXDL+E9hntK207pCEmz53MZ+s/o31Ge35x9C/IbZ1b7+fkNH5KSkwJbdlSsXekCps3w9df22LZAw6w5DhV4coowSTTA4Oq8vXWr5mzbg6L8haxcdfGCvtTJIWQhkhNSeWsYWdxfP/j4xrSKy4t5h8f/4PFeYvp0qYLNxx1Q5UKzGk5RPaOxo2DpUvNN9+OHRXLHXkknHuumaI7TixcGSWYxuQOKH9vPovzFrN4y2IW5S1iS8EWurTpwg8P+yF9s/vWqK29JXu58/07WbN9Db079Ob6I6+vldGE07yI7B1F0q6dhdHo1MnCbJSU2OLfSZNg2LCkiOo0clwZJZjGpIyi2Vm4k7at2sbVG4rFjsId3PHeHWzavYkhuUP4yaifuEcIh/nz4bnnbN3R4MGWunYtt7Bbvx6mTrV1TGBeHs46yzw+OE4YV0YJpjEro0SQV5DHbe/exo7CHXRr243ThpzGYd0Pq7WCc1oGoZA5gX3hBXNZlJsLF10Ue1Gt0zJpDMrITbubGN/s+Ib/++T/yCvIA6B3h96cMfQMDuh8gCslp0rWrrVouWvX2vZ++8HJJ5tSqumjU1ICn31mPvuGDIHjj/f1Tk2ZZCuj9sB3VPWhugjQmGgJygigJFTC+2ve56UlL5G/Nx+AgR0HcsbQM9zDuFMlJSXWS3rjDfMIDuYk9pRTzHlrdQpl0yYznHj//fJw72AOXs85xxVSU8XdASWYlqKMwhSXFvPOqnd45etX2FVkb4Z+2f0Y3m04h3Q7hO5tu3tvyYnJnj1m3PC//5UrlV69bE6pdWtbt5SSYm6URKzM++9bCIwwvXqZ2fj//mfDf0cdBRde6GuemiKujBJMrZVRcXFyw3nWkb0le3lz+Zu8vux19pbsLcvv1LoTB3c9mEO6HsLgToPdz52zD4WF1tN5/fXymE5VkZ5uzmXHjrUelYh5Kb/3XvsZHXYYXHpp8wn53lJwZZRgaqWM8vLgnnvgpJNsQUYTprCkkIV5C5m3YR7zN81nZ+HOCvvTUtJoldqK9NR00lPSaZXaqmy7VWor0lPSy/5vldqK1umtaduqLe1ataNtq7ZlqUNmh5jeJZymS3GxxVdassR6OaFQeSottd7OQQftGwIjzNKl8I9/wN691lu64gq32GtKuDJKMLVSRu+9B9On26/txz+2UJ/NgJCGWJm/ki82fsG8DfNYt3NdwtrOycrhnP3PYUT3ET4M6JSxZg38/e8WaHDgQLj66vhCsTvJJynKSEQOAkYB3YBMYCuwBHhfVbfVRZhkU+thuuees9Ca6enws5/BgAGJFy7JqColoRKKSosoDhXb39LiKrd3F+1mV9GuCil/b37Z/NTQ3KGcd+B5dG/XPcln5zQWNm6Ev/7VQly0bm3hMDIyoFUrSxkZFh5j0CCzwuvUKdkSO9CAykhEBgA/Bi4AugIhIB8oBLKB1kHeO8CDwOOqlcQ1aMTUWhmpwiOPWC+pTRu48UaLvObsQ0hDvLf6PZ5Z9Ay7i3aTIimcMOAETtnvlJheIUpDpewu3k27Vu28F9VC2LrVhuzWxdEZz801pTR0qJmaZ2XZsGBkCoXMg4TPQ9UfDaKMRORBTAm9C/wXeB/4SlVLI8rkAocDJwJnAwXApar6bl2Ea2jqZE0XCtks7BdfQMeO8ItfQHZ2QuVrTuwu2s0zi57h3dXvoqpkZ2YzceBEikqLyCvII68gj80Fm9m2ZxshDZHbOpcRPUZweI/D6dW+V0zFVBIqYfm25SzZsoSstCzG9RvnRhdNlFDIDCKKisxIIvLv1q02N7VkCRQUxNdedjZ897tw6KFuPl4fNJQy+idwh6quilOoFOA7AKr6eF2Ea2jqbNpdVGRjDMuXm3+VG27wQe9qWJm/kkfnP8rK/JUx94sIrVJbUVhSWJbXpU0XRvYYyYgeIyguLWZR3iIWb1nM0q1LKS4tLis3IGcAl4+4nJysnPo+DScJhEI2z7R4saVly8qj8qamlpuWl5SUO3898EA4/3wf3ks0bsCQYBKyzmj3brj9dtiwwRx9XXttkzb7bghUlffXvM/CvIXkZOaQ2zq3LHVq3YkUSWHZ1mXMWTeHuevn7mPlF0mPdj3Yr9N+zNs4j217ttEuox2XHXYZQ3KHNOAZOY0JVTM/f/ppWx+Vng7f/rYttI0OJ68K+fm2LqpnT1/zFC8NroxE5G/AddpMNVjCFr1u3Qq33WZP9cCBcPTRZtfarl3d227hhDTEki1LmLNuDvM2zCMzLZOhuUMZkjuEIZ2G0C7DrvGuol08+OmDLNy8EBHhrGFnMWHABJ93asHs2AFPPAGffGLbPXrAhAk2HLh+vX0/bthgw4Fg81Hjx9tiXB/gqJpkKKONwIfA91R1n9FaEfmWqr5SF4GSSUI9MHzzDdx5Z/mgtgj07w+HHGKpWzcfvK5nQhri+cXP88rX9kge2v1QLhl+SZ3CZ6gqmws2syhvETsLdzKo4yAGdhzoc1NNiAUL4D//sSCCsWjb1owd8vNtu1UrGDMGjj3WFJizL8lQRv2BF4G9wKmquj7IPxH4IzCyKXvxTrg7oB07zBvkvHk2qF1SUr6vWzc477z4AsRs324+U8BsWgcM8F5WDZi3YR5TPpvC3pK9dG7TmSGdhpCdmU12ZjY5WTlkZ2bTIaMDmWmZpKWk7dN72lm4k0V5i1iYt7AstlQk6anpDO44mKG5QxnWeRi92/f2Hlgjp7jY/OutXAldutjPMZzatrW5py+/hLfegoULy+sNHWpK6eCDfQgvkmStM+oAPAHsD/we+CEwBvgfcIuqzq6LQMmkXn3T7d1rT/W8eRZEJuzQa+xYOPtsyIzxtR492B1J1642BDhwoM3KuuVelWzctZH75twX1+LdFEkhLSWNtJQ0UlNS95mjatOqDUNzh9IhowNLtixh7Y61++wf23csJww4gbat2ib0PJyGZ/16ePtt+PDD8iG8nBz76R59NLT3wMnJM2AQkQnAM0AWMA/4sap+VBdBGgMN5ii1tNRcH7/4ov3fsSNcfHHFXtK6dRYTetky2z7oIOjd2/ymrFhhn3ZhMjLgV7+y+NFOpYQt77bu2Ur+3nzy9+azbe828vfms33vdopKiygJlexTLz01nUEdBzEsd1jMnk9lPaeMtAzG9R3HhIETKg31rqps2r2J1JRUclvn1s+JOwmhoABefmcjb7+/iy1bQighUlJDDN0/xOGHh+jdW0hNSSFVUkmRFFJTUsv+D2kIRQlpqCwBdMjoQE5WDq1SW1V63OLSYjYXbGbz7s0UlhbSOr01bdLb0Dq9tf3fqg2CUFBcUPZc5+/NZ3vhdvL35tO3Q1+O6nNUvV6bZAzTnQj8FjgCeBNYCvwAW1M0oy6CNAYa3Gv3unUWRnNVYDU/diycdpp9hr36qimq9u1tOO+ww8rnmEpLLajM0qUwd64prB49TCG1qvyhdqpHVSnVUkpDpZSESigOFdMmvU3cUXFVlRX5K3hpyUt8uelLwJTZ2L5jmThwIq3TW7MyfyXLti5j+bblLNu2jN1FuwGLLTWyx0hG9hjZpBRTXkEe8zfOZ/6m+eQV5NG1TVd6tOtRlrq17Vbh+qkqRaVFFJYWsrdkL1lpWXWKYlzfhDTEFxu/4PVlr7Ns6zIUm09atw62boHwGzQtDdJSISUwLU9NKf8/vC818m8aZLSCjEzIbt2WTlkd6dS6EzmZOewt2VumgMJhXqoirPBiMaLHCC4fcXmiLkdMkqGMQsDbwO/DC1pF5HLgH8BfVPX3tRJC5CTg70Aq8KCq/iVqvwT7T8YW1F6iqp9WVVdE7gC+DRQBy4Dvq2p+VXIkJYREdC8pJcUGrMGU05lnVm3KU1gIt95qflSOOcZ88DuNglX5q3jp65eYt2EeYI5mI7+Kw7TPaE9RaVEFj+l9s/vaWqruI+jUOvGLYopKi9i0exObdm9i+97tZKVnVXBm27ZVWzJSM8oUhKqWfdmXhkpZtX1VmQJav3N9lccSETpmdSSkIfaW7GVvyV6i3ztpKWllc3g5mTnkZJmJf/e23enWtluZlWRNUVV2FO6gsLSwzDmvIGX/Z6RlkJWWFVMRFpUW8cGaD/jf8v+xafcmALLSs8pCq6RKKnv2pLBiubBieQqFhaCEUEoJSSlKKUoIc06TgpCCIPa/pqASoki2U5SyDUkpJSMTMjNMObVubdPCbdtAWmoKua1z6dymM1lpWRQUF7C7eDcFxQVlSVXJTMskJyuHDhkdyuZEszOz6dm+Z73HKUuGMhqrqrNi5E/A5pFeU9XzaiSASCrm224CsBb4BLPWWxBR5mTgJ5gyGg38XVVHV1VXRCYCb6lqiYjcBqCqv6hKlqTGM4rsJXXvbkpl0KD46q5dC3/+sxlI/PCH5qPfaTSs2b6Gl79+mU/Xf4qI0Kt9LwbmDGRgx4EMzBlIx6yOlIRKWLB5gZmsb5y3zyLf/Trtx5DcIezXaT+yM7PL9pWESli9fTXLty1n+bblrMxfSXFpcdkQTuv01mSlZ9EmvQ0loZIyBRTv13b4i7uyr26AzLRMDuxyIAd1PYie7XqycfdG1u9cz7qd61i3cx2bdm/ap356ajqZaZlkpGaUvVCrom2rtnRv153ubbvTuU1nWqW2IlVSy4bCUlNsOGzbnm1l3jvCnjwiF0LHolVqK3KycuiY1ZGOWR3JycyhJFTC7NWzy3qtnVp34vj+x3NUn6NiWmOGQrbEMNpjRDjt2bNv2r3bfPBt2ars2LuDvSlbKQxSqmaSFepMa+3MgB45DOifQr9+NkXctWtFQ9yw38hYvfdQyGSJNSWdSBrVolcROQB4QVVr5CVURI4AblbVE4PtXwGo6p8jytwPzFTVR4PtxcB4oF91dYP8M4FzVPWCqmRJenC90lJTRn361NyR1qxZMGOGzR/95jdmIlQZBQU2nOfOuhqUnYU7aZXaioy0qmMjFJcWM3/TfOaum8uXm76s0GMC6Nq2K/2z+7O5YDOr8lfFnOeqjvAcVdc2XcnOzGZvyd4yZ7a7i83BbaRCBMp6AyJCbutcDupyEAd1PYiBOQNJTanciLYkVMLWPVtJS0kjMy2TzLTMfUKIFJYUVpjD27pnK5t3b2b9rvWs37l+n2tQE9q0akNWWhYAipb18lS1rKdWGf2y+zFx4EQO7X5ovYY92bPHlidu3WpRadasMUu/devMjimSTp0szMaBB5pfvkhFU1xs9b7+2tKyZTbAcs459SY6kBhllLC3kap+JSKja1G1J7AmYnst1vuprkzPOOuCzWvFdE0UDDNeDtCnT5+ayJ14UlNr7/H7mGMsjObcuTB5Mvzyl/sqm40b4dln4dNP7dOqY0dTWl27lv/t39+cvToJJ96hpvTUdA7rfhiHdT+MkIZYvX01i/MWl7k82rhrIxt3bSwr371ddwbkDChLrdNbU1BcwJ7iPewu3s2e4j0UFBcgInRp04UubbrQMatjtS/XklAJqkpqSiqC1HpOJy0ljS5tqvg4wobLurbtSte2XffZp6rk780vU0xb9myhJFRSNq8XnuMLaYjszOwy7x2d23Qmt3VutevK9hTvYdvebWzds5Vte+zv3pK9jOgxgoE5AxtkLisryzw+9OxZMb+wEFavNpulFSvMH9+WLfbtOWuWvTIGDTLbplWrrExJ1LdJXl69i58QqlVGInIR8J9Ix6iVoaqbgzqDgO5xmnnHutPR3bXKylRbV0RuAkqAmAYWqjoZmAzWM6pO2EaLCFx0kT2Ra9bAU0+Z4QPYbOuLL5pX8VDI5qVU7anesqXiQopWrWzZ+cSJvpapEZAiKfTL7ke/7H6cOOjEsvma1dtX07l1Z/rn9Kd1+r5zipFDebWlsSzkFRGbS8rKYf/O+ye8/az0LLLSs+jRrvGtaM3IMK9igwfbdihkyunLLy1C7ooV5b75wvTsWV5n8GDo0CE5steUeJ62nwO3iMgjwFOqOi9WIRHpBJwEnIcNoV0apwxrgd4R272A6MUglZVpVVVdEZkEnAoc31xdGFUgKwsuu8x84739NvTta72h//3P+u8i5tvk2982RZOXB5s2Wdq40bxGLFtmMaRnzrTVfRMn2ipAp1GQmpJa1gNyWh4pKRauvV8/OPVUm3dauNDcGPXpY3NKTXVgIx6v3bnAccA1wJHALmAhkEd5PKP+QB9gG/BvzMv3N3EJIJKGGSEcD3yDGSGcr6pfRZQ5BbiacgOGe1R1VFV1Ayu7u4Fx4R5bdSR9zihR/O9/8OSTFfMOPRROP736tUgrV1ovav58287IMKU0YYIrJcdxYtJQISRKgdGqOkdEjgGGASOoGOl1MfAeZmRQtelK7GOcDPwNM8+eoqq3isiPAFT1vsC0+59Yz6sAM9OeU1ndIH8pkAGEfbd8qKo/qkqOZqOMVOG+++Dzzy3i2Jln1nwuauVKeOEFGw8A61V16mTrmSJTt27uldxxWjgNpYx2ARNV9f1AMY1R1U/qctDGSrNRRmCDy3l50Llz3RyyrlhhPaUFC8rXP0WSkmIKL+wA1gPFOE6Lo6GU0UfAIuB6YCPWS3Jl1NIoKbG5pXXrKqZNmyranvbqBcOHm2Lq3ds9kztOC6ChlNFY4Ckg/Mn7LhZ6/IsgLYrH0q4p4MqoFuzebUN5n39u5j2FEWtTDj7YFuFmVL2uxnGcpk2DLXoVkXTgWOBV4A2gCzZ3lA4UYz2nL4B5qnpXXQRKJq6M6khxsdmYzpsHc+bY4tp+/eAnP3HjB8dpxiTDHdBs4CpV/SJwxTMUOBg4JPh7kKr2rqqNxowrowSycSP8/e+2jqlrVwu/7vNJjtMsaVTugJoDrowSzPbtcM895juvfXtTSL16JVsqx3ESTCKUkccqdOqPDh3g+uvN2m7HDrjjDvNn4jiOE0U8Bgx1ctimqqvrUr8h8Z5RPVFSAlOmmN+8tDRzUzRqlBs2OE4zoaGs6ULs6ysurrYBVdXK3fk2MlwZ1SOhEDzxhLkpAlNKQ4aYxd1BB/l8kuM0YRpKGfWtywFUdVVd6jckrozqGVVz1vree7aYNvLZ69nTXBYde6xb3jlOE8MNGBKMK6MGZOdOW5/0xRcV1ydlZpofvBNOqP+IYI7jJARXRgnGlVGSKCkxw4Y33yz3hde2LZx8Mowb50EAHaeR48oowbgyagR8/TU884yFsgALAPjtb8OYMeYHz3GcRocrowTjyqiRoGohLJ591mIsAeTmwoknwhFHuJdwx2lkuDJKMK6MGhmhEHzyiXkN37TJ8tq3h+OPt+G7rKyKZb/5xob7vv7aFNbJJ1cfv8lxnDrjyijBuDJqpIRC8Nln8MorFlIdzLhh3DgLa7lkCSxdCnv3VqyXkgLHHWchMSMVl+M4CcWVUYJxZdTIUbUYy6++ag5Zo8nNhcGDLa1cCbNnW5127SzA4JFHekgLx6kHXBklGFdGTYgVK2DWLEhNNXdDgwdDTk7FMqtXw2OPlRtD9O1r3h9qGvW2uVFYaNdv6VJLGzdaxN6+fctTTk7zUtyqUFQEu3ZZ2r3b/qakWNytLl2a1vmqQn6+3btNm8xD/sCBlpJg6OPKKMG4MmqGqNq803//az9esHDpw4db6tOnab2EakNBgQ1lhocz16yJHbU3krZtTSl17gzZ2eZnMCfH/mZn27BnY71uoZAFfly2DJYvt7R1qy0hqIzMzIrKuHdvO8dWrSzF84JXtWu9dWvFtH077NlTnvbutb9FRaYEe/cuT7162dAzWEiWLVssYnNenv2/ebMpoM2bbX80WVkwbBgceCDsv/++H2j1hCujBOPKqBlTWGhzTm+/XXFuKTvblNLBB9twXmlpxRQKmRFEU3JXVFRkL+KFC2HRIushRv7Ow72BQYOsR9mtG2zYAKtWlafdu6s/joi1FZmysuzrPNxb7dYtfqWlar2VjRstFRWZwUpkysy09kIhc767fbt9ZGzfbi/+FSssRQZ5DJOebkq2bVt74bdta8dYvbr8Q6UyUlKqV0x79sQ+bk3JybHz27696nLt2pky69LF5Fq0yK5bJD162LKIE0+su1xV4MoowbgyagGEF9h+/rkFAazuJQT28hk9Gk45xXoKyaKoyF42GzbY3/DLb+9e+1tYaHnr1lXsBaSm2tDkkCGmIPr3r9pJraq92FevLv+yz8+vmOJ96bZta8ccONCUQVjBh/+WlNgXf1gBFRRU3V56uimkXbsqKthocnPtnAcOtL/dutkLuzK2b6+ojNets+sdTvG+JzMy7MOlY8fylJ0NrVub3FlZ5X/T0mD9eguxsmaNpbVry3s8KSlWPzfX2szNtecvrIBiGeXk5ZlHk6++MuVUWGhzpZMmxSd/LXFllGBcGbUwVO2F+/nnsGCBvRhTU+0lkZpqSdWUVyhkL4cjjjCllKie0p498MYbZpaenm7HjvxbUmLKZ8MGUwzx/F5FrOczdKilQYMS7yFd1VIoVDHl55tpfdjEvrqv+2gyM01xdO1q/+/YUTGFlaCI9Qw6dChP2dl23gMHWi8qkedaWmpKqbi4/B5E34uMjLoPX4ZCNgSXlmY9pLrM/5SU2LBsmzZ2XeoRV0YJxpWRE5O8PHjpJfjww3KldNRRcNJJppRq8/IJheD9921h786d8dVJSbGXdPhl3aaNvbAzMsr/ZmTYV3N43iGZqNqL9euvy4cKU1LKFX04dehQfk7t2lV9PcM9wbZtra7TKHBllGBcGTlVsmmTKaWPPir/Km7TxuaUolN2duUv1a+/hscfL18zNXCgeStXta/ZkhL7Ai8psTa6dLE2c3P9Bew0SlwZJRhXRk5cbNxoSmnevH0X2oYJDzd162aTyN26WQ/gtdfg00+tTE4OnH02jBzZeC3THCcOEqGM3B2y49SUrl3hBz+wnsz27TYJHZ127bKFtytX7ls/Pd2G+CZOrHpS3XFaEK6MHKe2iNhwXHa2re2IZNcuU0obNpQrqM2bbUjujDMabP2H4zQVXBk5Tn0QNmkePDjZkjhOk8ADxDiO4zhJx5WR4ziOk3RcGTmO4zhJx5WR4ziOk3RcGTmO4zhJx5WR4ziOk3RcGTmO4zhJx5WR4ziOk3TcN10EIrIZWJVsORJILpCXbCHqmeZ+js39/KD5n2NzPz+AIarari4NuAeGCFQ1iZHTEo+IzKmr88LGTnM/x+Z+ftD8z7G5nx/YOda1DR+mcxzHcZKOKyPHcRwn6bgyat5MTrYADUBzP8fmfn7Q/M+xuZ8fJOAc3YDBcRzHSTreM3Icx3GSjiujZoqIZIvIUyKySEQWisgRyZaprojIFBHZJCJfRuTdLCLfiMjnQTo5mTLWBRHpLSJvB/frKxG5Nmr/9SKiIpKbLBnrgohkisjHIjIvOL8/BPm3iMgXwf17XUR6JFvWuiAiqSLymYi8GGzfEfwOvxCRZ0QkO8ki1gkRWSki84P7NSfI+05wT0MiUivLQVdGzZe/A6+q6lDgEGBhkuVJBFOBk2Lk/1VVhwfp5QaWKZGUAD9X1WHAGOAqEdkfTFEBE4DVSZSvrhQCx6nqIcBw4CQRGQPcoaoHq+pw4EXgd8kTMSFcS8Xf2xvAgap6MLAE+FVSpEosxwa/t7Di+RI4C5hV2wZdGTVDRKQ9MBZ4CEBVi1Q1P6lCJQBVnQVsTbYc9YWqrlfVT4P/d2IvtJ7B7r8CNwJNdpJXjV3BZnqQVFV3RBRrQxM+RxHpBZwCPBjOU9XXVbUk2PwQ6JUM2eoTVV2oqovr0oYro+bJAGAz8HAwXPCgiLRJtlD1yNXBEMgUEclJtjCJQET6AYcCH4nIacA3qjovuVLVnWAI63NgE/CGqn4U5N8qImuAC2jaPaO/YR8NoUr2/wB4pcGkqR8UeF1E5orI5Ylq1JVR8yQNOAy4V1UPBXYDv0yuSPXGvcBAbNhnPXBXUqVJACLSFvgv8FNs6O4mmvYLugxVLQ2G43oBo0TkwCD/JlXtDcwArk6iiLVGRE4FNqnq3Er234TdzxkNKljiOUpVDwO+hQ0lj01Eo66MmidrgbXhr07gKUw5NTtUdWPwggsBDwCjki1TXRCRdEwRzVDVpzFF2x+YJyIrsZf4pyLSLXlS1p1g2Hgm+84B/gc4u6HlSRBHAacF9+kx4DgR+TeAiEwCTgUu0Ca+nkZV1wV/NwHPkKDfnCujZoiqbgDWiMiQIOt4YEESRao3RKR7xOaZ2ERqk0REBJvnW6iqdwOo6nxV7aKq/VS1H/ahcVhwj5sUItI5bEkmIlnACcAiERkcUew0YFESxKszqvorVe0V3KfzgLdU9UIROQn4BXCaqhYkVcg6IiJtRKRd+H9gIgn6zbmj1ObLT4AZItIKWA58P8ny1BkReRQYD+SKyFrg98B4ERmOjWOvBK5IlnwJ4CjgImB+MK8C8OsmbiEYSXdgmoikYh/CT6jqiyLy3+DDKYR5zf9RMoWsB/4JZABv2PcGH6pqUz3HrsAzwXmkAf9R1VdF5EzgH0Bn4CUR+VxVT6xJw+6BwXEcx0k6PkznOI7jJB1XRo7jOE7ScWXkOI7jJB1XRo7jOE7ScWXkOI7jJB1XRk6VBF6xVURei7HvKRGZ2YCyjA9kObChjlkTRGSYiMwWkd2BnP0qKdddRF4Wke1BufEJlKFLcM9iHru5ICKnVnWNI8ol7BkVkTkiMjURbTn74srIiZeJInJ4soVo5NwBZGMLN4/A3BPF4ibMk/r3gnKfJlCGLtj6q34JbNNx6h1f9OrEw1Zs5f9NwBnJFaX+EJFMVd1bhyaGAs+r6ptxlPuoKSxmDdwThVS1NNmyOM0b7xk58aDAnzC/WwdVVigYHsqLka8icnXE9koRuVNEfiki64PhqrvEODkI0rVTRJ6txAt3DxF5MRgOWy0i+6xmF5GjReQdESkQkS0i8kDYjUmw/5JArlEiMlNE9gA3VHFuw0XkzaC9bSIyQ0S6Bvv6iYhifuSuC9qdWUk7irlnOjMot7IGMncX80y+XET2iMgSEfl/gZeNsKfv+UHxt4P2Nep820bJs1JE7ozYnhkMbV0uIsuAvUCPYN8Pg3tTKCKrROTGqLYOEJFXRWRrcG8WishVlV3ToM7PReST4BnYKCIviMigqDISPFubgudiOtA+Rlu9g+HPPcF5/bCSYx4oIi8Fbe0UkSclytdfUOY9EdkbnMdpVZ2HU3e8Z+TEy5PAH7De0XkJaO884GPMTdEI4P9hH0djgd8CWZgblT+zr3uYh4BHMPcjZwH3ishaVQ1H1jwKeBN4FjgH6AT8BcgJtiN5FPP8/QcgP5agItIZc+q5EDgfaBu094ZYVMv12HDbM8BbgVw7YrUVlPu/4Fi/xgLOxStzLtZL/RmwDdgPuBlzwXJFIMcFmFfoq6j98N9RmGL9BVAAbBeRG7APktuDazECuEVEClT1n0G95zG/chcG5zWEGEojil7YfV4VlP0R8J6I7Keq24My12Bey/8EzMbu+e2RjYiIAM9h1+hSTIn+AegIfB1RbhDwHjAHc72UCtwCvCAio1RVxfzmvQbkYfc7CwsN0ZYm7Puw0aOqnjxVmrCXXV7w/yVAKbBfsP0UMDNW2ag2FLg6YnslsBRIjcj7GHOv3z8i73ZgY8T2+KCtyVHtv4H5+wpvzwbejipzXFD3wIhzUeDaOK7BXzDl0T4ib1RQ/3tR53VnHO3NBJ6KyqtW5hjtpGEvy71AqyDvwKDO+Kiy4fNtG5VfQeZAtj1At4i89sAu4PdRdf8IbMBe6LlB+wfV4VlLxV78O4GLI/LWYeFQou+5Av2C7ZOD7dERZfoGz1TkM/oIsDh8vYK8wdhzfUqwfSVQDPSKKHNU0P7UhvrttbTkw3ROTfg3FvY6EWGTZ2rFeYilwEpVXRGV1zk8DBXBM1HbTwMjxAK3tcZ6H0+ISFo4Ae9iL5gRUXVfikPWUcDrGhGRVFU/xl7kR8dRv0rilTkYrvqpiCwIhhWLsV5QBtCnrnJEMFcregU/AovA+mSUfG9hjjN7YT22NcB9IvJdEekSz4FEZIyIvCEiWzDFUYD1QPYLivTGHKw+F1X16ajtUdiHSzhsCqq6CoiOLXQC9vyEIs5jBXYvR0a0NVdV10a09R4WENCpJ1wZOXGjFjr5duBCEelbx+byo7aLKskTIFoZRb8UNmG9hFxsWCsVGworjkiFWJjr3lF1N8Yha/dKym3EhoHqSrwy/xQLHvgMcDr20gzPyWQmQI4w0eeaG/z9Kkq+t4P83mrxpCZiPaUpwAYxM/dDKzuIiPQBXsfu8RVY7+Nw7H6Gzyc8lxPrnkfSLUZerHK52PBjcVQaQPl1jrctJ4H4nJFTU6YAv8F+0NHsJUpxSP2EAY/+6u6CfVXnYS8xxYYMY1mrrYvajsdt/foYxwTrFcSM6llD8olP5u8AT6rqTeEdIrJ/nMcIWwlGK/ZY9yf6mmwN/p5KbKW8GEBVFwFni1ngHQPchoUT6BUoq2hOAloDp6vqboCgpxKp4MM9tFj3nKhyse5RF2zYMfJcngEejFE2bHyzAbN4jNWWU0+4MnJqhKoWBtZXf8ZexMURu9cC7USkp6p+E+RNrAcxzgReidqeGwz77RaRD4EhqvrHBB3vI+DHItJOVXcCiK256ocNpdUJVY1X5iwCg4cILojaLgr+RveUwkNOw7AJfERkNNUbGAB8gL3Qe6hqtcOaqloMvCUid2ORW7MpV2iRZGExjEoi8s6l4ntpDaYcTgdejcg/K6qtT4Dfi8jo8FBd0PM6jOB8A97E5tXmajAZFINPgAsCJbo2aOsoXBnVK66MnNpwP2YJdiTwTkT+q9hLa4qI3IWFy66PIGLfEpFbg2OfBUzAXlZhbgTeFJEQZmSxE5tTOQW4SVWX1PB4dwM/Bl4Tkdsot6abj4UITwTxyPwGcI2IfAQswxTRoKh2VmP3YJKIbAeKVXUOZiDyDXCPiPwW633cSOVWf2Woar6I3Az8PRienYUN8e8HHKuqZ4rIwcCdwONYMMccrPc8T1VjKSKwOadU4GEReQg4ALieiOFaVS0VkduBO8WWDczGwpIPi2rrZWAeNq/1C6wn+Ef2HVq7ObgWL4nIFKw31BN7hqaq6kzgYaz3/1Jw3lmYxd0+yxacBJJsCwpPjTtRuYXcr7HhnJlR+d/C5hYKsBfHMGJb090ZVW8qMCcq7xIiLMAot6Y7EesZFWBf/FfGkG80phx3ALuxsOt3Ax1itR3HdTgUe3kWYC/L/wBdo8rsc16VtDWTKGu6OGVui70otwbpQWzorILFHaaklmC9JI3IPxz76i8APsPmaCrIXJlswb4Lsd7wHsy0/CPgZ8G+Lpil2nJMEWzAzOb7VHMtLsYU6x7gw+AaRMskmDLYjCnpGZgVYZk1XVCuD+UfRKuweagKFp9BuaFB/tag7FLsAyvSeu5g4H2sJ7oYW+w9B7emq7fkkV4dx3GcpOPWdI7jOE7ScWXkOI7jJB1XRo7jOE7ScWXkOI7jJB1XRo7jOE7ScWXkOI7jJB1XRo7jOE7ScWXkOI7jJB1XRo7jOE7S+f+9LbwUtFfZvQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_features=len(recovery_curve_keep_absolute[0])\n",
    "n_display_features=int(n_features*0.6)\n",
    "\n",
    "plt.plot(recovery_curve_keep_absolute[0][max(1,int(n_features*0.075)):n_display_features],\n",
    "         label='MCI', color='blue', linewidth=2, alpha=0.6)\n",
    "plt.plot(recovery_curve_keep_absolute[1][max(1,int(n_features*0.075)):n_display_features],\n",
    "         label='Shapley', color='green', linewidth=2, alpha=0.6)\n",
    "plt.plot(recovery_curve_keep_absolute[2][max(1,int(n_features*0.075)):n_display_features],\n",
    "         label='WeightedSHAP', color='red', linewidth=2, alpha=0.6)\n",
    "plt.legend(fontsize=12)\n",
    "xlabel_text='Number of features added' \n",
    "plt.title(f'Prediction recovery error curve, Dataset: fraud \\n the lower, the better', fontsize=15)\n",
    "plt.xticks(np.arange(n_features)[max(1,int(n_features*0.075)):n_display_features][::n_display_features//6],\n",
    "               np.arange(n_features)[max(1,int(n_features*0.075)):n_display_features][::n_display_features//6])\n",
    "plt.xlabel(xlabel_text, fontsize=15)\n",
    "plt.ylabel(r'$|f(x)-\\mathbb{E}[f(X) \\mid X_S = x_S]|$', fontsize=15)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27c0199b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6cb254a9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
