{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "964f481e",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "import sys\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt \n",
    "sys.path.insert(0, '../../ebl4game/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4c115b79",
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "from feature_valuation.explainers import ExactNew\n",
    "import shap\n",
    "import xgboost\n",
    "import numpy as np\n",
    "try:\n",
    "    import cPickle as pickle\n",
    "except ImportError:\n",
    "    import pickle\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from sklearn.neural_network import MLPClassifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f69ddadf",
   "metadata": {},
   "outputs": [],
   "source": [
    "%%capture\n",
    "def bool2int(x):\n",
    "    y = 0\n",
    "    for i, j in enumerate(x):\n",
    "        y += j << i\n",
    "    return y\n",
    "\n",
    "\n",
    "def cal(model, X, y, data_idx=1, type='fg',tempe=0.1):\n",
    "    \n",
    "    col_idx = 1 if y[data_idx] else 0\n",
    "    #print(f\"type: {type}\")\n",
    "          \n",
    "    if type == \"random\":\n",
    "        explainer = ExactNew(model.predict_proba, X, type=\"shap\",tempe=tempe)\n",
    "    else:\n",
    "        explainer = ExactNew(model.predict_proba, X, type=type,tempe=tempe)\n",
    "        \n",
    "    # calculate values given data_idx\n",
    "    shap_values = explainer(X[data_idx:data_idx + 1])  # 100 * 12 * 2\n",
    "    shap_values = shap_values[..., col_idx]\n",
    "    if type == \"fg\":\n",
    "        shap_values.values = np.log(np.divide(shap_values.values, (1 - shap_values.values)))\n",
    "    #print(shap_values.values)\n",
    "    if type != \"random\":\n",
    "        abs_values = -shap_values.values\n",
    "        mask_idx = np.argsort(abs_values)\n",
    "    else:\n",
    "        mask_idx = [np.random.permutation(12)]\n",
    "    #print(mask_idx)\n",
    "    #print(shap_values.values)\n",
    "\n",
    "    # Construct the mask.\n",
    "    v = len(mask_idx[0])\n",
    "    bin_mask = [1] * v\n",
    "    real_idxs = [bool2int(bin_mask[::-1])]\n",
    "    res = [explainer.all_outputs[real_idxs[0]][col_idx]]\n",
    "    \n",
    "    for idx in mask_idx[0]:\n",
    "        bin_mask[int(idx)] = 0\n",
    "        real_idx = bool2int(bin_mask[::-1])\n",
    "        real_idxs.append(real_idx)\n",
    "        res.append(explainer.all_outputs[real_idx][col_idx])\n",
    "        #print(res[-1])\n",
    "\n",
    "    res = np.array(res)\n",
    "    #print(res.shape)\n",
    "    #res = np.abs(res-res[0])\n",
    "\n",
    "    shap_values.base_values = shap_values.base_values[0]\n",
    "    shap_values.values = shap_values.values[0]\n",
    "    shap_values.data = shap_values.data[0]\n",
    "    return res, shap_values\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2d96da71",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[11:35:39] WARNING: /tmp/build/80754af9/xgboost-split_1619724447847/work/src/learner.cc:1061: Starting in XGBoost 1.3.0, the default evaluation metric used with the objective 'binary:logistic' was changed from 'error' to 'logloss'. Explicitly set eval_metric if you'd like to restore the old behavior.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch:  38%|███▊      | 45/120 [00:00<00:00, 445.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=0;diff=0.023862124690159178;time=0.00228167\n",
      "iter=1;diff=0.002047174058794065;time=0.00251770\n",
      "iter=2;diff=0.00012891605895993372;time=0.00224519\n",
      "iter=3;diff=1.181709406406958e-05;time=0.00213909\n",
      "iter=4;diff=7.954642604451235e-07;time=0.00232029\n",
      "iter=5;diff=7.271630790460497e-08;time=0.00211763\n",
      "iter=6;diff=5.202819506739889e-09;time=0.00214553\n",
      "iter=7;diff=4.665929011470223e-10;time=0.00211167\n",
      "iter=8;diff=3.499053713871536e-11;time=0.00216007\n",
      "iter=9;diff=3.070488175711493e-12;time=0.00212526\n",
      "iter=10;diff=2.378538907050842e-13;time=0.00213885\n",
      "iter=11;diff=2.0494065009794074e-14;time=0.00213242\n",
      "iter=12;diff=1.6615282515001883e-15;time=0.00210786\n",
      "iter=13;diff=1.233484761181068e-16;time=0.00247407\n",
      "iter=14;diff=1.1331166295920985e-17;time=0.00210929\n",
      "iter=15;diff=4.625929269271485e-18;time=0.00214672\n",
      "iter=16;diff=4.625929269271485e-18;time=0.00210428\n",
      "iter=17;diff=9.25185853854297e-18;time=0.00213242\n",
      "iter=18;diff=0.0;time=0.00211072\n",
      "iter=19;diff=0.0;time=0.00213885\n",
      "iter=20;diff=0.0;time=0.00213718\n",
      "iter=21;diff=0.0;time=0.00211072\n",
      "iter=22;diff=0.0;time=0.00216103\n",
      "iter=23;diff=0.0;time=0.00212717\n",
      "iter=24;diff=0.0;time=0.00217843\n",
      "iter=25;diff=0.0;time=0.00211692\n",
      "iter=26;diff=0.0;time=0.00212908\n",
      "iter=27;diff=0.0;time=0.00210690\n",
      "iter=28;diff=0.0;time=0.00213242\n",
      "iter=29;diff=0.0;time=0.00213790\n",
      "iter=30;diff=0.0;time=0.00215793\n",
      "iter=31;diff=0.0;time=0.00214672\n",
      "iter=32;diff=0.0;time=0.00210810\n",
      "iter=33;diff=0.0;time=0.00214148\n",
      "iter=34;diff=0.0;time=0.00213599\n",
      "iter=35;diff=0.0;time=0.00214291\n",
      "iter=36;diff=0.0;time=0.00211740\n",
      "iter=37;diff=0.0;time=0.00214171\n",
      "iter=38;diff=0.0;time=0.00215387\n",
      "iter=39;diff=0.0;time=0.00211048\n",
      "iter=40;diff=0.0;time=0.00213194\n",
      "iter=41;diff=0.0;time=0.00210690\n",
      "iter=42;diff=0.0;time=0.00213647\n",
      "iter=43;diff=0.0;time=0.00212121\n",
      "iter=44;diff=0.0;time=0.00231099\n",
      "iter=45;diff=0.0;time=0.00217557\n",
      "iter=46;diff=0.0;time=0.00217962\n",
      "iter=47;diff=0.0;time=0.00214672\n",
      "iter=48;diff=0.0;time=0.00211358\n",
      "iter=49;diff=0.0;time=0.00224042\n",
      "iter=50;diff=0.0;time=0.00211525\n",
      "iter=51;diff=0.0;time=0.00219917\n",
      "iter=52;diff=0.0;time=0.00216651\n",
      "iter=53;diff=0.0;time=0.00211167\n",
      "iter=54;diff=0.0;time=0.00211644\n",
      "iter=55;diff=0.0;time=0.00210261\n",
      "iter=56;diff=0.0;time=0.00213480\n",
      "iter=57;diff=0.0;time=0.00209761\n",
      "iter=58;diff=0.0;time=0.00212884\n",
      "iter=59;diff=0.0;time=0.00213838\n",
      "iter=60;diff=0.0;time=0.00210476\n",
      "iter=61;diff=0.0;time=0.00211644\n",
      "iter=62;diff=0.0;time=0.00215054\n",
      "iter=63;diff=0.0;time=0.00213456\n",
      "iter=64;diff=0.0;time=0.00210738\n",
      "iter=65;diff=0.0;time=0.00216126\n",
      "iter=66;diff=0.0;time=0.00213122\n",
      "iter=67;diff=0.0;time=0.00213695\n",
      "iter=68;diff=0.0;time=0.00212407\n",
      "iter=69;diff=0.0;time=0.00212193\n",
      "iter=70;diff=0.0;time=0.00213027\n",
      "iter=71;diff=0.0;time=0.00209975\n",
      "iter=72;diff=0.0;time=0.00213265\n",
      "iter=73;diff=0.0;time=0.00215149\n",
      "iter=74;diff=0.0;time=0.00217175\n",
      "iter=75;diff=0.0;time=0.00212836\n",
      "iter=76;diff=0.0;time=0.00214815\n",
      "iter=77;diff=0.0;time=0.00211072\n",
      "iter=78;diff=0.0;time=0.00211382\n",
      "iter=79;diff=0.0;time=0.00230598\n",
      "iter=80;diff=0.0;time=0.00211000\n",
      "iter=81;diff=0.0;time=0.00212622\n",
      "iter=82;diff=0.0;time=0.00211024\n",
      "iter=83;diff=0.0;time=0.00211954\n",
      "iter=84;diff=0.0;time=0.00209975\n",
      "iter=85;diff=0.0;time=0.00214958\n",
      "iter=86;diff=0.0;time=0.00210786\n",
      "iter=87;diff=0.0;time=0.00213933"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 429.69it/s]\n",
      "Epoch:   0%|          | 0/120 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "iter=88;diff=0.0;time=0.00218081\n",
      "iter=89;diff=0.0;time=0.00301647\n",
      "iter=90;diff=0.0;time=0.00231433\n",
      "iter=91;diff=0.0;time=0.00212169\n",
      "iter=92;diff=0.0;time=0.00231123\n",
      "iter=93;diff=0.0;time=0.00231767\n",
      "iter=94;diff=0.0;time=0.00235629\n",
      "iter=95;diff=0.0;time=0.00230503\n",
      "iter=96;diff=0.0;time=0.00214529\n",
      "iter=97;diff=0.0;time=0.00215769\n",
      "iter=98;diff=0.0;time=0.00237608\n",
      "iter=99;diff=0.0;time=0.00232100\n",
      "iter=100;diff=0.0;time=0.00215077\n",
      "iter=101;diff=0.0;time=0.00217175\n",
      "iter=102;diff=0.0;time=0.00215459\n",
      "iter=103;diff=0.0;time=0.00224638\n",
      "iter=104;diff=0.0;time=0.00222707\n",
      "iter=105;diff=0.0;time=0.00221682\n",
      "iter=106;diff=0.0;time=0.00221086\n",
      "iter=107;diff=0.0;time=0.00211072\n",
      "iter=108;diff=0.0;time=0.00212860\n",
      "iter=109;diff=0.0;time=0.00213242\n",
      "iter=110;diff=0.0;time=0.00215697\n",
      "iter=111;diff=0.0;time=0.00217342\n",
      "iter=112;diff=0.0;time=0.00212717\n",
      "iter=113;diff=0.0;time=0.00212407\n",
      "iter=114;diff=0.0;time=0.00210357\n",
      "iter=115;diff=0.0;time=0.00212264\n",
      "iter=116;diff=0.0;time=0.00213623\n",
      "iter=117;diff=0.0;time=0.00212073\n",
      "iter=118;diff=0.0;time=0.00210238\n",
      "iter=119;diff=0.0;time=0.00231791\n",
      "iter=0;diff=0.02386212468569722;time=0.00220656\n",
      "iter=1;diff=0.002063665319263213;time=0.00213742\n",
      "iter=2;diff=0.00013025764346179423;time=0.00213432\n",
      "iter=3;diff=1.1938096105995928e-05;time=0.00210285\n",
      "iter=4;diff=7.870652422831801e-07;time=0.00213027\n",
      "iter=5;diff=7.210846019716668e-08;time=0.00211787\n",
      "iter=6;diff=4.990041258358495e-09;time=0.00213075\n",
      "iter=7;diff=4.505009035424598e-10;time=0.00212789\n",
      "iter=8;diff=3.2553991649595065e-11;time=0.00212955\n",
      "iter=9;diff=2.881202593521715e-12;time=0.00211358\n",
      "iter=10;diff=2.1542428962723828e-13;time=0.00213480\n",
      "iter=11;diff=1.871656241676146e-14;time=0.00212336\n",
      "iter=12;diff=1.4469031232228833e-15;time=0.00212145\n",
      "iter=13;diff=1.050809133373904e-16;time=0.00213933\n",
      "iter=14;diff=1.850371707708594e-17;time=0.00212407\n",
      "iter=15;diff=4.625929269271485e-18;time=0.00213695\n",
      "iter=16;diff=0.0;time=0.00213933\n",
      "iter=17;diff=0.0;time=0.00214076\n",
      "iter=18;diff=0.0;time=0.00211692\n",
      "iter=19;diff=0.0;time=0.00215197\n",
      "iter=20;diff=0.0;time=0.00213003\n",
      "iter=21;diff=0.0;time=0.00216150\n",
      "iter=22;diff=0.0;time=0.00215554\n",
      "iter=23;diff=0.0;time=0.00212336\n",
      "iter=24;diff=0.0;time=0.00214243\n",
      "iter=25;diff=0.0;time=0.00214410\n",
      "iter=26;diff=0.0;time=0.00214005\n",
      "iter=27;diff=0.0;time=0.00212193\n",
      "iter=28;diff=0.0;time=0.00253606\n",
      "iter=29;diff=0.0;time=0.00213981\n",
      "iter=30;diff=0.0;time=0.00212669\n",
      "iter=31;diff=0.0;time=0.00213575\n",
      "iter=32;diff=0.0;time=0.00210142\n",
      "iter=33;diff=0.0;time=0.00212717\n",
      "iter=34;diff=0.0;time=0.00220346\n",
      "iter=35;diff=0.0;time=0.00216985\n",
      "iter=36;diff=0.0;time=0.00212574\n",
      "iter=37;diff=0.0;time=0.00210428\n",
      "iter=38;diff=0.0;time=0.00214171\n",
      "iter=39;diff=0.0;time=0.00210404\n",
      "iter=40;diff=0.0;time=0.00212860\n",
      "iter=41;diff=0.0;time=0.00212598\n",
      "iter=42;diff=0.0;time=0.00212669\n",
      "iter=43;diff=0.0;time=0.00214052\n",
      "iter=44;diff=0.0;time=0.00211906\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 431.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=45;diff=0.0;time=0.00222254\n",
      "iter=46;diff=0.0;time=0.00213838\n",
      "iter=47;diff=0.0;time=0.00215101\n",
      "iter=48;diff=0.0;time=0.00213861\n",
      "iter=49;diff=0.0;time=0.00214672\n",
      "iter=50;diff=0.0;time=0.00219893\n",
      "iter=51;diff=0.0;time=0.00221562\n",
      "iter=52;diff=0.0;time=0.00221658\n",
      "iter=53;diff=0.0;time=0.00483608\n",
      "iter=54;diff=0.0;time=0.00217366\n",
      "iter=55;diff=0.0;time=0.00215602\n",
      "iter=56;diff=0.0;time=0.00218296\n",
      "iter=57;diff=0.0;time=0.00213432\n",
      "iter=58;diff=0.0;time=0.00214338\n",
      "iter=59;diff=0.0;time=0.00273848\n",
      "iter=60;diff=0.0;time=0.00229740\n",
      "iter=61;diff=0.0;time=0.00214958\n",
      "iter=62;diff=0.0;time=0.00215602\n",
      "iter=63;diff=0.0;time=0.00214744\n",
      "iter=64;diff=0.0;time=0.00247908\n",
      "iter=65;diff=0.0;time=0.00214887\n",
      "iter=66;diff=0.0;time=0.00216246\n",
      "iter=67;diff=0.0;time=0.00238633\n",
      "iter=68;diff=0.0;time=0.00217342\n",
      "iter=69;diff=0.0;time=0.00238991\n",
      "iter=70;diff=0.0;time=0.00215316\n",
      "iter=71;diff=0.0;time=0.00213099\n",
      "iter=72;diff=0.0;time=0.00217009\n",
      "iter=73;diff=0.0;time=0.00256681\n",
      "iter=74;diff=0.0;time=0.00230289\n",
      "iter=75;diff=0.0;time=0.00230193\n",
      "iter=76;diff=0.0;time=0.00215960\n",
      "iter=77;diff=0.0;time=0.00241733\n",
      "iter=78;diff=0.0;time=0.00240207\n",
      "iter=79;diff=0.0;time=0.00213480\n",
      "iter=80;diff=0.0;time=0.00220466\n",
      "iter=81;diff=0.0;time=0.00212789\n",
      "iter=82;diff=0.0;time=0.00218654\n",
      "iter=83;diff=0.0;time=0.00264454\n",
      "iter=84;diff=0.0;time=0.00212955\n",
      "iter=85;diff=0.0;time=0.00215387\n",
      "iter=86;diff=0.0;time=0.00217557\n",
      "iter=87;diff=0.0;time=0.00212741\n",
      "iter=88;diff=0.0;time=0.00213718\n",
      "iter=89;diff=0.0;time=0.00210977\n",
      "iter=90;diff=0.0;time=0.00213885\n",
      "iter=91;diff=0.0;time=0.00210381\n",
      "iter=92;diff=0.0;time=0.00211716\n",
      "iter=93;diff=0.0;time=0.00214982\n",
      "iter=94;diff=0.0;time=0.00210857\n",
      "iter=95;diff=0.0;time=0.00217080\n",
      "iter=96;diff=0.0;time=0.00210595\n",
      "iter=97;diff=0.0;time=0.00212216\n",
      "iter=98;diff=0.0;time=0.00213313\n",
      "iter=99;diff=0.0;time=0.00222135\n",
      "iter=100;diff=0.0;time=0.00211787\n",
      "iter=101;diff=0.0;time=0.00211072\n",
      "iter=102;diff=0.0;time=0.00214601\n",
      "iter=103;diff=0.0;time=0.00210643\n",
      "iter=104;diff=0.0;time=0.00215364\n",
      "iter=105;diff=0.0;time=0.00211191\n",
      "iter=106;diff=0.0;time=0.00213838\n",
      "iter=107;diff=0.0;time=0.00215387\n",
      "iter=108;diff=0.0;time=0.00213885\n",
      "iter=109;diff=0.0;time=0.00213575\n",
      "iter=110;diff=0.0;time=0.00213051\n",
      "iter=111;diff=0.0;time=0.00215459\n",
      "iter=112;diff=0.0;time=0.00227618\n",
      "iter=113;diff=0.0;time=0.00213957\n",
      "iter=114;diff=0.0;time=0.00210905\n",
      "iter=115;diff=0.0;time=0.00212479\n",
      "iter=116;diff=0.0;time=0.00211883\n",
      "iter=117;diff=0.0;time=0.00214458\n",
      "iter=118;diff=0.0;time=0.00210810\n",
      "iter=119;diff=0.0;time=0.00213361\n"
     ]
    }
   ],
   "source": [
    "#%%capture\n",
    "def main(model, data_idx=2, tempe=0.1):\n",
    "    # get a dataset on income prediction\n",
    "    X, y = shap.datasets.adult()\n",
    "\n",
    "    # train an XGBoost model (but any other model type would also work)\n",
    "    #model = xgboost.XGBClassifier()\n",
    "    #model.fit(X, y)\n",
    "    #rand_diff, rand_coff = cal(model, X, y, data_idx=data_idx, type=\"random\",tempe=tempe)\n",
    "    #shap_diff, shap_coff = cal(model, X, y, data_idx=data_idx, type=\"shap\", tempe=tempe)\n",
    "    #banz_diff, banz_coff = cal(model, X, y, data_idx=data_idx, type=\"banz\", tempe=tempe)\n",
    "    fg_diff, fg_coff = cal(model, X, y, data_idx=data_idx, type=\"fg\", tempe=tempe)\n",
    "    \n",
    "    #print(rand_diff)\n",
    "    #print(shap_diff)\n",
    "    #print(banz_diff)\n",
    "    #print(fg_diff)\n",
    "    \n",
    "    #res = np.vstack((rand_diff, shap_diff, banz_diff, fg_diff))\n",
    "    #coff = [rand_coff, shap_coff, banz_coff, fg_coff]\n",
    "    #print(res)\n",
    "    res = None\n",
    "    coff = None\n",
    "    return res, coff\n",
    "\n",
    "\n",
    "X, y = shap.datasets.adult()\n",
    "# train an XGBoost model (but any other model type would also work)\n",
    "model = xgboost.XGBClassifier()\n",
    "model.fit(X, y)\n",
    "# the last of coff is variational index\n",
    "res, coff = main(model, 0, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "583a4c6e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAoQAAAGrCAYAAABZpYYxAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nOzdd3gU1foH8O9sNtmS7KYXQhrEQAIIKChIs8BVEURQUWyIXh2w4PWKvStFsCIImuFnAwtwAUVExEYVREARpAuEBEJCes9mN3t+f2wSUjaFtNkk38/z7JOZM2fOvLtZhjdz5pyRhBAgIiIioo5Lo3YARERERKQuJoREREREHRwTQiIiIqIOjgkhERERUQfHhJCIiIiog2NCSERERNTBMSEkIiIi6uCYEBIRERF1cEwIiYiIqN2RJClQkqQfJUnKkiTpQ0mSXpMk6dEG7vu7JEk9WzpGVyLxSSVERETU3kiS9DYAvRDiQUmSAgHsAXCBEKKoAfveAuBWIcRNTY1DURQdgIUARgDwA/APgGdlWV5Xxz5xABYA6AcgDcATsix/1ZC2atu3vjh5hZCIiIjaoxEA/le2PAnAdw1JBst8A+BKSZI6NUMcWgBJAC4H4A3gBQDLFUWJclZZURQtgNUAvoUj6ZMBfKYoSrf62qpn33qDJCIiImoXJEnygOPKmBnAGkmSTpStf1SpzusAYoQQ48rW3wBwMYBrhRBWIUSxJEm7AVwN4NOmxCPLcgGAlysVfasoygk4ruAlONklFkAogHdkWRYAflEU5VcAd8my/EI9bdW6LxzJY62YEBIREVG7IYQokSTpMgAbhBDBACBJUhqAw5WqzQFwTJKkvgAGArgWwBAhhLVSnYMA+jg7hqIo3wIYUksIW2VZHl1bfIqiBAPoBmB/LVWkWsp6NaCtBu9bHRNCIiIiam/6Avir0roPgLzyFSFEhiRJcwEshqPrdYgQIqdaG3kAnHYZ15Xw1UVRFHcAnwP4VJblQ7VUOwTgLIAnFEV5B8CVcHQRb2hAWw3a1xneQ0hERETtTfWEMAuAqVqdPwFcCOAZIUSSkzZMALKbKyBFUTQAlgAoAfBwbfVkWbYCGAtgFIAUANMALAdwqr62GrJvbXiFkIiIiNqbPnAkTOX2wtG1uhMAJEm6EMD7cNwfeC+AL5y0EQfgM2eNK4qyDsDQWo69RZblkdXqSwA+BBAM4LqyxK1WsizvhePKXvn+28pirbetuvatCxNCIiIiam/6AHi80vp3cCRJn0uS1BnAGgBTAPwE4IQkSVcIITaWV5YkSQfHQI27nTVePeFrgPfhSDBHyLJc70hnRVF6AzgCR0/ug3B0XX/SkLbq2bdWTAiJiIio3ZAkKQSALxz305VbDGCPJEnecCSHbwshvimr/waAmQAGV6o/BsBGIURyU+NRFCUSwGQAFgApiqKUb5osy/LnZXXWwXFlcVbZtrsA3AfAHcAWAP+SZdnSkLZq27e+ODkxNREREbV7kiTNAnBWCDG3AXV3APi3EOLvlo/MNTAhJCIiIurgOMqYiIiIqINjQkhERETUwTEhJCIiIurgmBASERERdXBMCImIiIg6OCaERERE1KFIkrSk/lodC6edISIiog5FkqQCIYSn2nG4El4hJCIiIurg+Og6amm8BE1ERC5l/PjxQMv+/yS1YNstgl3G1NL4BSMiIpdisVig0+la8hBtLiFklzERERF1KKdOnVI7BJfDhJCIiIg6FE9PjiepjgkhERERdSgeHh5qh+BymBASERFRh5KVlaV2CC6HCSERERF1KMHBwWqH4HKYEBIREVGHkpmZqXYILocJIREREXUoVqtV7RBcDuchpJbGLxgREbkUzkNYE68QEhERUYfCeQhrYkJIREREHYqXl5faIbgcJoRERETUoWi1WrVDcDlMCImIiKhDyc7OVjsEl8NBJdTS+AUjIiKXUlBQ0NKPr2tzg0p4zZSISA3r/gBS+LQEohZ1RS+gS81JqNPT0/k842qYEBIRtbbcQojRMyEZ+DxVohZjF0C3UGDP2zU32e0qBOTamBASEbU2IQCtG1BgUTsSovbt6Blg1z9A/wuqFIeEhKgUkOvioBIiIjXw/m2illdUAsxaWaM4OTlZhWBcGxNCIiIiap+EcNyvezqjSrHZbFYpINfFhJCISA1SmxuESNQ22QUw91u1o3B5TAiJiNTALmOi1lFiAz5YDxSeu2c3NzdXxYBcExNCIiI18AIhUesRAli8sWI1NDRUvVhcFBNCIiI18AIhUespsACzVlRcmU9JSVE5INfDhLAVde7c+ZGwsLBSRVEa/adJZGTkJ3FxcS0+gVJERMRPgwYNSm/p4xARtQkPjQR2vg4ULwM+frjh+/38CiBWAW7871Z1WQXAD3sAABoNfx/VNXoeQkVR5gAYDSAcQD6AtQCekmU5s2x7HwCzAfQFEAJgqCzLWyvtPxTAumrN6gEckGW5d7VjaQBsBXAZgHBZlk81Nu66dOvWra/dbv88NTW1e0lJiZuXl1dpWFjYmd69ez+3ZMmSxU1t//Tp0/MAzCtfDw8P3xoaGnrhjh07vJvadmUxMTF9AHyWmpoaa7FYtAaDwR4YGJgXExOzauzYsQ/Islzv5GeJiYkjmjMmIqqGg0pc00u3On6+sqxqeXImMGMFcE1foKETit8+DNAy8XAZ+cXAq/8DrrkIAQEBakfjcpryTS0FcCcAfwB9AIQB+LjS9hIAqwCMcbazLMtbZFn2Kn8BMAM4DeAzJ9X/C6CwCbHWKyws7NLExMTdZrM5cNSoUTe98MILutDQ0HAhxHenT5+WW/LYzSkiImJAUlLSHyaTKXjkyJG3TZkyxdNsNnt5e3s/f/z48aEAeOMEkSvgoJK25asdwOrfgYy8htU3G4GXbgGeXNKycdH5+fM4cCCJXcZONDohlGX5WVmW/5Rl2SrLchqA9wBcUWn7QVmWF8myvLOBTV4Hx5XEykklFEXpBuBBAI83NtaGsFqtX0RERNinTJkSu3Tp0tXPP/98yb59+87s3bt38i+//DIEAGJiYm4NDQ3NNhqNdi8vL3uvXr3SpkyZUnElLSgoKGHgwIGJERERx3U6nQgJCbHedNNNH5Vv79y58+NBQUFCUZSwqKio95KTkwfv2rXLrNPphE6nE/Pnz78qODh4QFhYWJqnp6fdaDSKbt265dxzzz0TG/o+LBbLF5GRkaVTpkzptmzZshXvvvtuYWJiYtGuXbveO3ToUIwsyyca8l7Cw8O3DhgwIKd8XZIkMWLEiJ+Cg4Mz9Xq9iIiIKJ40adKDTf3ciYjapVl3AO9/z+dVu5oSGzB7FXx8fNSOxOU057Xs4QD2NmH/KQBWliWXACq6ij8C8ASA7PoaUBRliKIo2XW8nMYnSZIxLS0tunv37rvKu7yd8fDwsF522WWv/vvf//bu3Llz1/T09JIdO3asVhTFvbzOnj17wgcOHPjL+PHjjb6+vi9/880390ydOnVq9bYSEhIeDg0N/bV///65FotFslgs0tSpU3/RarXo16+fMmHChMDOnTsHFBUVJWzcuPEjRVEC63v/kiQZ0tLSunbr1m2XLMt1fl4NeS/VHT169PJRo0bdFxoaarDb7Yd+++23dxVFMdYXFxE5wS7j9qtfNDA4Fpj/ndqRUHWlduB/21B6tt6UosNplmcZK4pyE4D7AVzeyP3DAYwEcFW1Tf8BkCLL8ipFUaLqa6fsHsXGpP2+Qgh4enom1VVp//79qyqt5vn6+j567Nix5QBiABwAgF69ehWOGDHiflmWBYCZgYGBkw8ePPgIgPkNCeT06dM7AOwoX5ck6Q4A+9LS0oYA+Kqe3f2EEPDy8qp4H5Ik9dXr9X9IkiRZrVY8+OCD/3333XfnNuS9VNe/f/+fP/roo1UA4O3t/WpWVtbKsvp/1RZQXl4eTCYTl7nM5SrL+fBil7HrWPMsMCTOsawv+5v40dGOn1sPAtfPanhbkgQslIH/fOhIPsj1aCQU7D8BxEUDaJl/421RkxNCRVHGA4gHMEaW5T8a2cz9AA7LsrypUrsXAJgGoH9TY2yALEmSUFBQEF5XpZiYmOEWi2VxVlZWiNVq1QCAxWIBgIqrdyaTKaMsGQQA6HS60wUFBd0bGkhYWFgPd3f3NZmZmZEWi8VNr9ejuLgYaWlpXRr6PvLz8yPKC4QQewBoJEkKA5CEst95Q95LdZ6enonly7m5uZllo7Tq/PZX/sfBZS5zuXzZC4JXCF1H5YSvtkElDWU2AP2jgWXTHOvlo4tPLQLGv+lIMEldnf0ROnpIxWpL/Btvi5rUZawoyj1wJIPXy7K8oZFtaAH8u6ydyobAkZz8rShKOoDyZHOvoihO711TFGWooij5dbz2O9tPCFEYGBh47PDhw/0URfGtLdazZ8+uioyMLLn55ptji4uLJYPBcEvZpooze15enr+iKBXrFouls6enZ0YtTZZWL7DZbN/4+vr6jh079pJ58+ZpiouLLyyLsd7fVdn7OHHkyJE630dD3wsRtSBeIWxb3DSAzt3xs/JydTmFQOh9QN9pjtd1Mx3l/Z4Adhxt3ZipJi898MJ4nDp9Wu1IXE5Tpp15BMBLAK5xNnCkLCnSVSryUBRFD8Aqy3LlROh6AL4Aqk/rshzAT5XWwwBsB3A1gEPOYpJleQsAr/N8K47gPDzuTExM/DU+Pv7ghg0b5O7du69buXKlryRJLwYGBvb5+eefh1qtVp1Opyvq3r17UmxsbKxOp5tXvZ2///7b+PPPP8dv27Zt6o4dO/6blZUV3r179/86O6ZGo0nOysoaPGvWLO9nn302BwBsNpvR3d3dFhkZeeLNN9/sFBYWtvzUqYbPsqPT6e5KSEjY/MEHHxz65ZdfHvL391/7448/2mNjY28/dOjcx9aQ90JERGWeHw+8fOu59buuAF5e5riSGB4AHHgX6PEfICkdSK10f1p5F3RqNruQXYFWA9w6GO4pZ9SOxOU0pcv4XQA2ABsURakoLJtCBgAiAZyoVP/nsp/3APikUvlkAMtkWa4yFEuW5UJUmmqm7Eoi4LinML8JcTuVlJT0W0xMTP+cnJzPv/3221WrVq1y8/T0LI2IiEgODQ19BgAiIiIe++OPP97asmVLUWBgYEmnTp2Wp6am3lm5nb59+57atm3biLNnzxb7+PjYxowZs7hPnz7vOjtmdnb2iwaD4ZoZM2ZkzZgxQ5o9e/ZVPj4+9x8/fnzpnDlzsnx8fGw9evRYderUqbiGvo/ExMRfu3Xrdmlubu7i7777bmlxcbGb0Wi0BwQE5I0cOXJRRETE+w19L0TUgthl7Jpq6yp+ZVnt25LSAdMdzredTAOkG5snNmoavTvw6PWAhzv8/PzUjsblSILdFs0mKCgooXfv3raffvrpArVjcSH8ghFVl1MAETgJkrXGXSNE1FL07kDSIiDAjGPHjiE6Orolj9bm/uLjFOpERETUvrlpgJsvAwLMAABf3zpvs++QmBASEamBXcZErcdDCzx9ruu+pKRExWBcU7PMQ0gOZ8+ejVI7BiJqI3i7DlHr6RsF9KyYkQ0FBQXqxeKieIWQiEgNvEJI1Dq89MALt1QpCgsLUykY18WEkIhIDbxCSNQ6fDyBa/pWKTqf6dw6CiaERERE1D556oBnbgQ0VdMdnU5Xyw4dFxNCIiIiap8kCZh0VY1is9msQjCujYNKiIham8EDlm4h0GcV1l+XiBrvv2MAY82rgWlpaUwKq+HE1NTS+AUjciIlJQUhISFqh0HUIWVnZ8PHx6clD9HmRo2xy5iISAUeHh5qh0DUYRUW8up8dUwIiYhUkJWVVX8lImoRRUVFaofgcthlTC2NXzAiJ/Lz8+Hl5aV2GEQdksViaemRxuwyJiKi+mVmZqodAlGHxXkIa+IoYyJqH46lAC8tVTuKmow6YPadgJ+pSrHValUpICIyGAxqh+BymBASUfuwdjfEsq2QbHa1I6nKXQuE+ACv3lalmI/OIlKP0WhUOwSXwy5jImo/3FzwlGa1AfPWApaqVwTZZUWknoyMDLVDcDkuePYkImoclx0kV2oHvtxSpYgDSojUExgYqHYILocJIRG1Iy46sC+/GJixAqiUsGq1vGOHSC25ublqh+BymBASUbshuWg+CABIyQY27a9Yzc7OVjEYoo7NYrGoHYLLYUJIRO2Gy3YZA0BBMTDjfxWrfGwdkXo4qKsmJoRE1G5IrtplXO7XQ8A/ZwAA6enpKgdD1HFxUFdNTAiJiFqLzQ68sRoAYLe72PQ4RB2Ip6en2iG4HCaEzSQyMvKTuLi4Jp3hIyIifho0aFCrXDaQJElMnDhRcYVYiJqLaOyTEn29gFVPAflfAAnxwG1Da6/7+A3AvrlA7ufA8fcd6+XCA4C8z6u+xCrgsTGO7bZSYMlGIKeAXcZEKvLw8FA7BJfjssPcFEVxAzAbwCQAegA/AJgsy3KzJynh4eFbk5OTB2u1WkiSBG9vb1vv3r23jh8/fqQsy8XNfTwAMJlM+cOHD9/59ddfX1lelpiYOKIljtUYrhQLUUNJ9Y0qeelWx89XllUtX3A/UGIDgu8F+kYBa58D/koADiQ5OwgwcR6wNwGIDgF+eAlISgeW/er4abrjXN2oIOCfBcDK7VXbUH5E8o0XIjo6+jzfIRE1h6ysLPj5+akdhktx5SuETwO4AcAAAOV3fy5pqYP1798/12KxSBaLxc3X1/eJn3/++YrNmzd/0FLHI6Lm16hBJUYdcNNA4IUvHAM/fj0EfLMTuOty5/Xf+Br487hjbsEjycDq34HBcc7rTrwC2HwAOJl2rqyoBHj9a5iN7LIiUktwcLDaIbgcV04IZQBzZFk+LstyDoAnAVyrKEpUSx5UCGE/dOjQXJ1OV5KWlnZpebkkSdrY2Ngl/v7+xUajUURGRhbecccdz9XWTvfu3d8LCAgo0uv1wtfXt/Syyy478Nprr4UAQGho6IGCggLPtWvXXqHT6URcXJxNURS38PDwrQMGDMgpb6Nr167dIyMjj3l6epb6+vqWXnrppceeeOKJmEoxiREjRvwUHBycqdfrRURERPGkSZMeLN8eFxf3dEBAQKFerxcmk8l+0UUXnVUUxbd8e3Jyctfa9q0eiyRJ4sorr9wUFBSUo9frRdeuXQvuvffee5v6eRM1p0YNKukW6kjujp45V/bXSaBneMP2HxoH7E90vm3iFcCnG2uWF5fAY91f5xspETWTzMxMtUNwOS6ZECqK4g0gAsDu8jJZlo8ByAXQu5Z9hiiKkl3Ha29Dji1JkltcXNyTxcXFHt7e3ofLyyMiIhYXFRVNGDVq1MR+/fq56/X6t1evXj39qaeeus5ZO15eXmeuvvrqCdOmTXPv3LnzNXv37r3g119//QYAkpOTe3h6ehaMGjVqo8VikQ4ePKiVZbm0WhzarKys7UFBQV733HNP95CQkO4JCQnmrVu3bi/rTgcAHD169PJRo0bdFxoaarDb7Yd+++23dxVFMUqSZDxy5Misq6++etm8efO0Xbt29TWbzS8AKKlv39o+m0OHDg257rrrHunWrZvJbrf/um7duv978803uzbkcyVyWV56IKewallOAWAy1L/vy7cCGg3w8S81tw2JA4K9gRXba27LL4b+zTWNi5eImsxqtdZfqYNxyYQQgLnsZ0618uxK26qQZXmrLMs+dbycJpLl/vjjD7PRaBQajcZ2+PDhOZdffvnBESNG3AUAkiRJZ86cuWXYsGGLFy9evHzLli22w4cPP+/u7p55+PDhJ5y1t3v37plffPHF6pkzZ9r+/vvvnwICAr49ffp0nTFU5ubmNiA/P9/3hhtuuO+999775+DBg/9Yrdb7du/e7V9aWlpx5bJ///4/f/TRR6uOHz9enJeX92pSUpIWQAwAaDQakZGR0W3btm29/vrrr5xNmzbFy7Jc0JB9nenfv/+OTz755NO9e/fmnzx5cmxaWhr27dv3ZF3vIy8vj8tcbrVlp4NK1jwLZC1xvJ4e53iVr6951vEUEXO1v4PMRiCvqGZblT000nEFcNRMx/2H1d19JbDyN0c3tBPuZU8qcYXPjctc7mjLPj4+Ldp+W+SqCWH5p+pdrdwHjquEze7iiy/OLSwslKKiokyRkZE/nTp1KjojIyOgbHOA1Wp1W7Fixb1Go1GUvwoLC/0LCgo6OWuvR48ez3bq1CnH09PTbjAYxJkzZ8YVFhbqGhqPv79/T5PJhKCgoAPlZdnZ2futVitOnjzZs7zM09Ozoq8qNzc3s7i4GABMQojCbt263XHkyJHw5cuX/xkWFmYZNWrUKkVRtPXtW1tMZrP5WPmyEKJQr9cX5efnd6nrfZhMJi5zudWWnXYZXz8L8L3L8Zr9leNVvn79LMd9gFoNcEGlf8p9ooD9TgaUlLvnKuDpG4HhLwOnM2pu13sA4y8DPt3gfH8vPdLky5v8frnMZS43brnyk4Jaov22yCVHGcuynK0oSiKAiwHsAQBFUbrCcXXQadevoihDAayro9mTsiz3rGM7AODYsWP5kiSNMpvN6Zs3b/7mmWee6Q0g3d3dvfS2225b8NFHH/2nvjYkSQqXJGnmuHHjVoaEhExesGBBRmRk5CoA4yrVqXOKmoyMjP2SJCEtLS0WwDEA8PHx6VFQUICwsLADde1bbv/+/UsBLJUkyc3b2/vhdevWze3ates0AHMasn91ubm5FUMiJUkyurm5Gby8vE40pi0il1FoAVbtAF6dANy3EOjbBbjhEmDQs87r3z4MmHUHcOWLwIlU53XGDQCyC4ENfzvfrndH8cg+zRM/EZ03Ly8vtUNwOS6ZEJZRADylKMoGABlwJDHrZVlOcFZZluUtAJrlNyyEKAkPD39569atbz333HNXCSF+iYyMXL5p06Ypt99++29XXHHF8g8++MDs5uZ2e+/evY99+OGH31drwksIAS8vr7OJiYmZvXv3viE9PX105Ufl6HS63JycnChFUTSyLNdIDktLS3f4+PhkrV69+sPU1NRBP/zwA9zd3Rf169cvw8PDY0d970GSpOCrrrrq+bCwsPeEEIe7d+9+BgA0Gk2jb5zYvXv3gEmTJt25Y8eOVZGRkauKi4vRu3fvNxvbHlFzExCNe1bJgwrw0UPA2Y+BjDzgAeXclDND4oB1z6NiOpkZtwH+JmDn6+f2/2wz8ED8ufW7rwAWb3R+LIMH8PgNCAjhKEcitWi1rpz+qMOVP5HZAHwB7ASgA/AjgDtb6+CnTp1619vb+8Xt27d/CKBLYmLixNjY2IIff/zxw1WrVn3h4eEhQkNDM7Va7QPV9xVCHIyJiflyxYoVk+12+wNRUVHZYWFh2wBUzGPh6+v74p49exbu2LHDNnfu3NJHH31UX60NW3R09JDU1NS1H3744VF3d3fExMScHDx48HXVB6DUQnP48OGbt2/f/tCyZcskb29v28iRI9f27Nnz3cZ+Jt27d9+6du3ahXl5eUs6depUeO21106eNm3aP41tj6i51TsPYfX5B8tl5QPjarlwvvUgqswt2LXGP/marp1e9/bJ1yAlJYXzEBKpJDs7G/7+/mqH4VIkl34YPLkMSZLEXXfdtWjx4sXyee7KLxi1jnlrYX/iE2hKGvL3kkq0GmDSVcCiB5GRkcH/kIhUUlBQ0NKPr3PxB6vX5KqDSoiIzluj5iFsTVo34MmxAACbzcnIZCJqFenpfDJrdUwIiYhay2XdgZhQAEB+fr7KwRB1XHZ7neM6OyRXvoeQXIgQwsUvvRA1YVBJa/DUA8+Pr1itPMiMiFpXSEiI2iG4HF4hJKJ2w6W7jIO8gSt7VayeOnVKxWCIOrbk5GS1Q3A5TAiJiFqapx54/mag0ihod3d3FQMi6tjMZqcPPevQmBASUbvh9NF1rsBNAm4fWqXIz89PpWCIiGpiQkhE7YZkd8GE0N0NePg6x+PsKklNreUpJ0TU4nJzW+QpuG0aB5UQUfsw8iLkf78TppadW+z8eeqAx8bUKPb19VUhGCICgNDQULVDcDmcmJpaGr9g1GpSUlI4epCI6nXixAl06dKlJQ/hwiPcnGOXMRG1Gx4eHvVXIqIOT6Nh+lMdPxEiajeysrLUDoGI2oCAgAC1Q3A5TAiJqN0IDg5WOwQiagNSUlLUDsHlMCEkonYjMzNT7RCIqA3w8fFROwSXw1HGRNR02w8Dt70NtNYgtf4XACufrFFstVpb5/hE1KbZbDa1Q3A5TAiJqOn+PA5xJgtSSSudZNPzgN8OAwO7Vynm84GJqCHy8/N5i0k17DImouahacVZFopKgBkrahTz+cBE1BD847EmJoRE1CxadU5TIYCf9gKJaVWKvby8Wi8GImqz+MdjTUwIiahtEgJ4Z02VIq2Wd8EQUf3c3d3VDsHlMCEkomYhSa08MX+JDVj0I5BfVFGUnZ3dujEQUZvk5+endgguhwkhETULVR6DKQB8sqFilY+tI6KGSE1NVTsEl8OEkIiaRatfIQSAQgvw2krAbgcApKent34MRNTm+Pr6qh2Cy2FCSETNQpUrhACQWwSs+wMAYC9LDBslMw8YNxvwvA2IlIEvNtde942vgV7/AUy3A12mONYre+EL4MJHAe3NwMtLGx8TEbWIkpIStUNwOUwIW5miKBH33HNPsVar3d+ENq4YPXq0XZKkn5ozNqI2Kb8YmP4/AA3sMn55qfMk7aFFgIcWSP0I+Py/wAMKsD/ReRtCAIsfAbKWAN+/ALz3HbB067ntF3QCXp8IjOrXiDdERC2toKBA7RBcjssnhIqiuCmK8oaiKGmKouQpirJSUZQWeyq1oijmJ554YtHFF1+c6+3tbdfpdHZvb+/CoKCgdZIkxTS1fVmWEz/++GO9zWbrWXa8SZdcckmuJEn/1/ToHVqiTaL6qNJlXG7vSWDfSSQnJzdu/4JiYOVvwPTbAS8DMCQOGHMJsGST8/pPjgMujga0bkD3zsANlwK/Hjy3/e4rgZEXAyZD4+IhohbFeQhrcvmEEMDTAG4AMABA+W9wSUscSFEUr4SEhF3z58+/JyEhYZOHh0fcK6+8Ynz44Yfv79OnjxeAUS1xXKL2QLUuY8Ax4nj2KpjN5sbtfyQZcNMA3ULPlfWJBPYn1SUmdikAACAASURBVL+vEMCWg0DPiMYdm4haHechrKktJIQygDmyLB+XZTkHwJMArlUUJaoFjvXoypUro2w227bMzMzr09LSDj/99NPFM2fO/PzHH38cKoSYqyhK2OTJk3+PjIy0Go1GYTQaS7y9vddLkhQEAIqivBwZGZnVp0+fP3r27Fmi0+nsZrM5VZKkkWXboyZNmiTc3NxOKIpy2ffff7/ojz/+MGk0mn/rdDqh0WiKnnzySa9p06b9HB0dXeLl5WU3GAw2b2/v3yVJim6ONzlv3rzxV199dUpAQIDdYDDYfHx89kqS1Ks8PlmWd4aFhdn0er0wGo02vV6/rWzbiLFjx57y9/e36/V6u8lkKpYkaVZzxETUJKV2YNVvkNJyG7d/fjHgbaxa5u0J5BU5r1/Zy8scg1ruuapxxyaiVqfT6dQOweW49CyuiqJ4A4gAsLu8TJblY4qi5ALoDSDByT5DAHxbR7OJsiz3drahuLh49NGjR7VCiMV17K9JTk5eWVBQ8NikSZP2hISEvPPJJ5/clZeXNw/ABADQ6XTe+/fv7+nh4XHDa6+9lrF3794fFy9evFqSpG7x8fEVDcmyvB3A/UlJSfN27dq13GKx3Ff2Hry2bdv2U05Ozlv9+vXbdO211z62fPnyF/ft27cUwCV1xFYvRVEu++WXX77YtGlTmru7+4XTp0+/YOPGjSu///77jZIkdY2Pj5/12Wef9SgtLX3g4Ycf/sjPz6/vokWLIgHgzJkzn69Zs8YHwIXvv//+PwkJCf967bXXOKyTAKjcZQw4pqD5dAMwx8nfTaNnAlvLunSLrY6fc8tOE0PigOm3AbmFVffJLay/y/e974DFG4EtMwAdJ7olaisa3ZvQjrn6FcLy31hOtfLsStuqkGV5qyzLPnW8nCaDAFBQUBAkhJAAnK6tjizLiWvWrJmTnp6+deHChfkhISGPXXfddTpJkv5VXqe0tLSktLR0eWFh4brHHnvs90GDBs0PDQ0tAHB7Q960LMv5n3zyyWvp6enfbdq0qeCZZ56ZPnr06PzS0tL+kiR5NqSNOtyzcePGopKSkpfy8/P3P/7446tHjx79P51Op4ejS7xEq9VKZrP54rfffjvwueee252QkLAKADQajRWAJjAwcNDkyZPdZ82a9a0Q4re6DpaXl8flDrKsapcxALi7waN3l4rVKnF++QiQ/RmQ/Rks/x0FPD0OyP4MeUnvA98+B3QLhbCVAkeTz+37VwLQM7zW91u0cC0wexXw88vI89Y5rWO1Wp3Hw2Uuc1nV5dOnT59X/fNdbotc+gohgPJP17tauQ+ARvYN1c7T0/OsJElRQojOtdVRFCXg77///mT9+vXDz5w5oyspKZEAwG63V0x7brPZilH16mVCYGCgdPr06QbdxaooiuH48eMfrF279uakpCRDcXGxVOnqS1MH1ITn5eUZABwvL9BoNMd8fX1LCgsLwwE8MWnSJI9NmzbdWVRUJPv4+ORYLJbZRUVFrwcHB4+69dZbF+zevXtBdnb2B/7+/iczMzOnCCF+qO1gJpOJyx1kWfUrhCY9MgZGVfylWFucOp1HzXJPPaQbBwIvLgX+70GY9p4CVu8Ets1y3s7nm2B4dSWw4VWgawjO1SirY7UBpXa4u2kBmx0oLoHJaKzZDpe5zGVVljt16tSi7bdFLp0QyrKcrShKIoCLAewBAEVRusJxdXCvs30URRkKYF0dzZ6UZbmnsw16vf7bmJiYi48dO3YXgNpG6L62ZMmSq2w226L8/Pzn4+Pjxd69e3MXLFhQUUGr1eoBRFXaJyotLU0AcHYXq93Jf6SPrVix4sYzZ858X1paKhcXF2e88MILWTNmzPAB0NT/dZNMJlNRTk5OxaUUu93eNSsrywNAkizLaSi7krlgwYKuR44c+fG9996bKUnSLiHEL7IsD1EURcrJybli586d61esWLFGkiRfIURhbQekjkEI0eQvZ6MZdcDTN0LTlGcZL5SBexcAQfcA/ibgffncQJEtB4CRM4D8Lxzrz38JZOQBlzx5bv87hwEfTHEs3/++o/u63MwVwMcPA5N4nyGRKygsLISPj4/aYbgUl04IyygAnlIUZQOADABzAKyXZTnBWWVZlrcA8Grksd698cYbJ7799tuD/fz8vgbwxOOPP55YVFR0w++///7QDz/8sCo+Pt5ssVg0Npvt7FtvvWVPSkpa+P3331dpxM3NzcPNzW28Xq9fMmfOnIw9e/Y8nJyc7AnA2Qy1Kb6+vjqNRhMjSZJGCGEHYC4uLpasVmvm/fffXzh9+vTZ3377bfWrpPXSaDQeo0ePrtjv2LFj1kceeeSTyy+//J7169e/bDQat86YMSNm48aN4y0WSy6Ate+8887tb731Vqe0tLRP58+fn+Pp6VksSZIwGo2YMmXKU998882JM2fOfLtgwYI0g8Eg4LhzqwmzARM1AwnAvcMRIDXgq/jyBOflfibg66edbxva41wyCAAnPqj7GJ9MdbyIyCUVFTVgwFgH4+r3EALAbABrAOyE494+NwB3tsSBZFnO69KlS/+pU6d+HBUVNdxmsx155ZVXiubNm/fJn3/+mQ9gLYCXJkyYkODt7f3qM888kzt37twh/fr1q/K/kMViyenZs+eB6Ojob5988smdK1asKAEwVghx3Mlhf7n00ks3hIWFDTIYDDY3N7e8zMzMuTfeeOOBgICAexctWlTw+uuv3xMbG5t2Pu/F3d3dZLfb71q7dm12+evQoUMFDz74oP2qq66aOHToUHeDwXDgueee+3rz5s2HS0tLrxRC5Gq12r4mk2mGu7t72tSpU9Pmz58f7ubm9tI777yz1Ww2j/bw8Phcr9cXPPbYY3tXr16dJoQYJ4QobvynTu2Fal3G7lrg3uGAlwEpKSnqxEBEbQrnIaxJUv1G8HZGUZSXZ86c+Z/ExMS3hBAz1I7HBfAL1hEsXAf7Yx9DY7G1/rH17sCh+UBkEDIyMuDv79/6MRBRm3Ls2DFERzfLTG61Ufmm6vPXFq4QEhHV7speQGQQAMBmUyEhJaI2x2DgU4SqY0JIRM1ClS5jTx3w/PiK1fz8/NaPgYjaHKPRWH+lDoZdxtTS+AXrCNTqMo7tDByYB5QloxaLhU8gIKJ6scu4Jl4hJKJm0epXCL30wAvjK5JBgM8nJaKGCQwMVDsEl8OEkIiaRav3Nri7AeMHVS1y5+PjiKh+ubnN/myLNo8JIRG1PXp3YNoYx5Qzlfj5+dWyAxHRORaLRe0QXE5bmJiaiFydJDlumDF41Fez+TxwbY2i1NRUeHk1dl56IuooOA9hTUwIiajp7rwcaZkZCGqt+3JiOzueLFKNr69v6xyfiNq0U6dOtfSgkjaHo4yppfEL1kGkpKQgJCRE7TCIiOrVCucrjjImoo7Jw6MVu4uJiJqA56uamBASUbPIyspSOwQiogbh+aomJoRE1CyCg4PVDoGIqEF4vqqJg0qIOorSUqCopOnt6NxrTPcCAJmZmRzhS0RtAs9XNTEhJOooHvkQ4oP1kNya2DEQ4gMc/wDQulUptlqtTWuXiKiV8HxVE7uMiTqKpHRIdgFYS5v2yioAVv1Wo3nO60VEbQXPVzUxISSi85NfDEz/X41iPkeYiNoKnq9qYkJIROfveCqw40iVIt6PQ0RtBc9XNTEhJKLzV1QCzFpZpUir5S3JRNQ28HxVExNCIjp/QgA/7AFOpVcUZWdnqxgQEVHD8XxVExNCImocuwDeWVOxysfWEVFbwfNVTUwIiahxSmyA8iNQUAwASE9Pr2cHIiLXwPNVTUwIiajxhAA+3QAAsNvtjW8nMw8YNxvwvA2IlIEvNtded8M+4MoXAe87gajJNbdHTQYMEwCv2x2vq19pfFxE1C416XzVTjEhbAJJkoYajUahKMpljW2jc+fOjwcFBQlFUTgpErU9BRbgtVWA3d6wLpiXlzpe1T20CPDQAqkfAZ//F3hAAfYnOm/DUw/cexXwxsTaj7PmGSD/C8frh5ca9l6IqMNgl3FNqiWEiqJoFEXZpihKiyVD4eHhWyVJEldfffWhyuWSJIW6ubkJSZKEoihXNLZ9IcSWwsJCSZbl7QAQGRn5SVxcXLP+2SFJkrFbt24/+fj4lOh0OmEymexdu3bNvfvuux8v2x4lSZKYNm3a1PNsV0ycOFFpzlipg8ouANbvQXJycuP2LygGVv4GTL8d8DIAQ+KAMZcASzY5r39pDHDXFUBXPouUiBqn0eerdkzNK4T/BVDY0gcJCgqy7dmzJ0ZRlIjysoiIiJf9/f2b9FDX0aNHG5oeXf3Cw8O/KS0tHTZmzJjx8+fP18TGxob6+vq+brPZslrj+ET1yi8Gpi+H2Wxu3P5HkgE3DdAt9FxZn0hgf1LjY7pjLhA4ydFd/NeJxrdDRO1So89X7ZgqCaGiKN0APAjg8ZY+VlRUVKHVas3ZvHnzqwAgSZKUlZV1W3R09PrK9WJiYm4NDQ3NNhqNdi8vL3uvXr3SpkyZMqJ8e1BQUMLAgQOTIiMjj+r1ervFYtkjSdIVbm5uQlGUIaGhoVNOnz5995EjRySdTid0Op2YOnXq45IkhUVERJzy8vIqNRgMIioqquD2229/rqHx5+Xl9Y2Njd23ePHi1bIsi507d6bs3r17xueff/4hAHh4eBwFgPfee2+eTqcTw4cP/6fs/Xzl5+dn0el0IiAgwDZ8+PBtiqJ4AoCfn186ACxduvR+nU4nLr300mwAMJlM+WPHjt1QfuzqVx9jY2PvCA4OztXr9cLLy8seHR2dqyhK98b9Zqhd2ZMAt0ON/Is7vxjwNlYt8/YE8ooa197njwIJHwAn44ErewHXTHdcxSQiolq1+syMiqJoAHwE4AkA9U4EpCjKEADf1lElUZbl3nW1YTKZPjp48OADiqLcGxAQMEan0xlTU1MVANeX1/Hw8LD27t371dDQ0EU//PCDf3p6+q87duxYrSiKjyzLVgD466+/wsaMGfPBhRde2HP79u0mABeW75+cnPxBZGTkQKPROPHgwYMVifZ7770X0aNHj1WdO3d+fcuWLVklJSUr1q9fP2POnDlrnnrqqb31vX+TybRr+/bt1wwbNmy92WxeHRERsWLhwoVny7eXlJTEADjx8MMPP/LWW2/NLy/39vY+OmDAgGuMRuPm7du337558+bFQUFBH8qyPCEzMzNAkiQxYcKERYsXL5bri6FcUlLSoquuumrnZZdddvXSpUs1Op3udjTgd0gdgNUGLN0KDO1Tc9vomcDWg47l4rIHys8t+yc9JA6YfhuQW62zILcQMDXyIvzguHPLz9wEfLoR2HIAuP6SxrVHRO1Obm4uAgMD1Q7DpagxVfd/AKTIsrxKUZSo+irLsrwVgE9TDpiUlPTa2bNnHz1x4sQtHh4eT/Xu3fuvdevWVUlk9u/fv6rSap6vr++jx44dWw4gBsABALjwwgvzli1b9kBZnQxJkuo9thAiEcAj5euSJN0CIPfEiRM3A6g3IUxKSrq+V69e806cOHFzWlrav4QQC3799deUYcOG3TR//vxtte23a9euJyutfta5c+dpp0+fvrzegOug0Wjs2dnZnQ4ePHjp3r17twD4sL598vLyYDKZuOwCy1abDe71/L4azcMdmkoJV5UYvnykYtnyzGLodB7AyxPO1SkohrCVQjqaDMSEOsr/SgB6htf9vpwdy9myBBQWFsLY0Ppc5jKX2/2yt7c3yrVE+21Rq3YZK4pyAYBpAB5uzeMKITICAgL+2Lx586sZGRm9L7744unV68TExAyPiIg4bTKZSvV6vSgqKlqel5cHABV/QphMpvOeuMhkMgVGR0f/5ePjY9Xr9cJgMOQCQEFBQYMG0gghrPv27XsgKSkp0GKxuPfo0ePuEydO+G7fvv0HRVFqzUjj4uIWBAUFFRiNRrvRaBRnz57tW1xc3KSHN4aFhY1OTk7GqlWrNoaEhFivvPLKzYqi1Nlm5X8cXFZ32b0lH9UUFYSs7uf+2q4tBp3Oo2a5px7SjQOBF5cCBcUw7T0FrN4J3HW583bsdpjcdYC1FBDCsVziuPJoyioGfj0IlFgd5W98DaTnwTji4npj4zKXudxxlsv+f2+x9tui1r5COASOBOtvRVGAcwnpXkVRnpdleWH1HRRFGQpgXR1tnpRluWd9By4uLn55+/bta/v165cfERHxNYDBlbefPXt2Ve/evTOHDx8e+/HHHx/19fUdb7FYlgOoSLokSapvBHFp9QIfH59lWq22+5gxY/41ZMiQzZMnT/YEkCuEOO9kXAhRCmBxZGTkuJSUlLEAfAHUiMnLy+vykpKSB2+++ea3OnXq9NJbb71V0Llz5z+FEDF1ta/Vai02m82zfF2n04VbLJaK7QcPHtwIoJskSVJ0dPT4rVu3Lg0NDV0oy3Id839Qu+elB14YD42mCX9fLpSBexcAQfcA/ibgfRnoWTYObMsBYOQMxxQyALD5gGMewnKGCcDlPYGN04G8IseUNcdSAL070LcLsO55R5tERGWadL5qp1o7IVwO4KdK62EAtgO4GsAhZzvIsrwFQJOubAFARkbGugEDBjwQExNzQJZlMXly1QltrVarTqfTFXXv3j0pNjY2VqfTzTvfY9jt9hOZmZnSK6+80u2ll146UlZmdnd3t/v7+x9/4403TFFRUV8lJCQ0uM0ePXqsvuCCC3b7+Ph8umTJksS+fftenZ2dfU3Pnj2zZFnOnDx5cpEkSUhNTe1fvo+7u7ufzWaD2Ww+/fbbbxetX79+SlpaWp/Q0NCKG7WMRmNRdnZ2j8rH8vLyOnjo0KFL//Of//Rcu3Zttr+//6flQ/MlSfIYMGDAOzExMR/Gx8f/+c4775yWJEloNBrr+X5O1M7otMBNAxFQYqm/7ssTnJf7mYCvn3a+bWiPc8kgAFzRCxCrnNftGQHsfaf+OIioQwsICFA7BJfTqgmhLMuFqDTVjKIo5cdPkWU5vyWPLYQQAD6obXtERMRjf/zxx1tbtmwpCgwMLOnUqdPy1NTUO8/nGKdOnVoQGho6ec6cOYfmzJkj/fvf/54G4L6MjIyfFy5ceNLLy6v0sssuW3/y5EnR0Dbtdnve77///kROTs7LOp1OSkpKKo2NjT0ybNiwG8veV1FMTMynq1evvtNgMNw1aNCgf7Kzs2O7dOmyafHixW8Zjca3tVptSlhY2D4A0eXthoWFvbFp06ZnjUaj/cILL8zesWOHX3Fx8Z1CiF/j4+P/9vHxscXGxn6ZnJzcpdL7u3bfvn1Tli9frvHy8iodPHjwzqFDh049n8+I2hmDB/DYGMBdi5TEk4iOjq5/HyIilaWkpPB8VY3kyJOIWgy/YK5izCxgza7mbVPvDpz+P8DPhIyMDPj7+zdv+0RELaAVzlf1jzp1MexEJ6LGcdMAtw11dPcCsNlsKgdERNQwPF/VxISQiBrH3Q14alzFan5+i971QUTUbHi+qokJIRE1zqUxQPfOFathYS3ySHIiombH81VNTAiJ6PyVTTVT2alTp1QKhojo/PB8VRMTQiI6fwEmYHjVJ0a6u7fYc1CIiJoVz1c1MSEkovPjqQeeuxmo9uhGPz8/lQIiIjo/PF/VpMazjIlIDd6esOu10Hg08S9jjQa4Y1iN4tTUVHh5NXkOeSKiFsfzVU2ch5BaGr9grqKgGOm/72/6DP0hPkCgd43izMxM/tVNRG1CK5yv2tw8hLxCSNRReOqh6dMFaKGTIJNBImorSkpK1A7B5fAeQqIOJCsrS+0QiIhUV1BQoHYILoddxtTS+AVzIfn5+bxvhog6PIvFAp1O15KHaHNdxrxCSNSBZGZmqh0CEZHqOA9hTbyHkKgtEALYcgCwWBtWv08UEORTo9hqbeD+RETtWAtfHWyTmBAStQVbD0L86xVIBo/665bagegQYM/bNTbxcU1ERIDZbFY7BJfDLmOitqDEBhg8gJzC+l/5xcDRM8Cuf2o0w24SIiIgLS1N7RBcDhNCojbCbrc3vHJRCTBrZY1iDighIgL8/f3VDsHlMCEkao+EAL77A0iuOohEq+VdIkREhYWFaofgcpgQErURGqkRsxjM/bbKanZ2djNFQ0TUdhUVFakdgsthQkjURtjPd85QixV4/3ugyFJRFBIS0sxRERG1PRxgVxMTQqI2QmrMFUIhgMUbK1bT09ObLyAiojaKA+xqYkJI1J4VWByDS8quLp7XwBQionbKYDCoHYLLYULYRvj5+c2Ni4sTiqKc93VuPz+/Q9ddd11GS8RFrafRj5nMzAd+/AtAE7uMM/OAcbMBz9uASBn4YnPtdTfsA658EfC+E4ia3PhjEhG1AKPRqHYILqddDjlUFGU/gMhKRW4A9AD6ybL8R3Mdx83NbaxWq/1qzpw5kx599NFPAUCj0YwRQqweN27ciVWrVnUtr+vp6Zn9r3/9K/frr7+OaK7jU8ei0TTy77f8YmD6/4Cr+yI5ORnR0dF11395adnPCVXLH1oEeGiB1I+APQnAqJmOJ6L0dPKV9tQD914F3DbE6fQ3RERqysjIgI9Pzac5dWTtMiGUZbln5XVFUWYCGNucySAA2O32X6xWq9i/f/+tAD4FAD8/v1u1Wq31xIkT4YqieMuynCNJ0gUAvLt06bKiMccZPXo0r20T7HY73Bq78+5jwMFTMAc0cnb+gmJg5W/A33MBLwMwJA4YcwmwZBMw+66a9S+Ncbx++quxERMRtZjAwEC1Q3A57b7LWFEULYB7AcQ3d9tCiFyz2XwiMTFxcHlZSUnJVUOHDt146NAhYbfbLwcAg8Fwnbe3N+Li4pYBgCRJ/hEREb+ZTCab2Wy2X3TRRWlPPPHEdeVteHp6Zg8fPvx4p06dEnU6nTCZTNurHzssLOxJb29v63333bcIAHQ6XWBkZORWHx+fEr1eL8LCwkoeeuihV5zF3blz543e3t4ler1ehISEWMeNG/ezoiieZbH5du7c+U+j0VhqMBhESEiIddKkSUsAwGw2XxISEpJiMBjsnp6eIjIysujFF1+8uzk/U6pdI4aUnFNiA+Z81fj9jyQDbhqgW+i5sj6RwP6kpkRFRKSK3NxctUNwOe3yCmE1YwF4A1hcWwVFUSIA7K2rEVmWnV5b1mg03x87duxBRVFiJk+enOvh4REwbNiwj9etW3fR33//PQHAN0aj8eYLLrjADmArAPj5+f1iNptjx48ff+2yZcv2nD59+pd169Z9ExMTEy3L8kkA+PPPP7vcdNNNb0dGRj6za9cuLwAvlh+zc+fOH1qt1okTJ058dv78+W9IkqTx8fH5zcfHJ/T666+/6eTJk9/9888/gy0Wi9PHUgQGBv55/fXXP7t///7fT5069dCaNWvmRkZGvgNA9vPze83X17f3nXfeOeD111/fHRUVdbHNZosoe69Le/fuLYYNGxb8wgsvZJvN5pFWq/V0XZ8bNaPGjDIuV2oHlm1F/sOXN+4v4/xiwLvaPTfenkAe5/IiorbHYrHUX6mjEUK061d8fPyP8fHxH7dU+wCu0Gg0Yvbs2f/RarV39OzZ0xofHx/k7++/cvTo0WcASDqdrvCWW27ZX1Y/FICYNm3awkptdAcgnn/++VlCCBiNxuxrr702s/JxfH19515wwQUiIiJiV9euXUueeuqpcZX2v1Sj0YiZM2dOcxajr6/voZEjR2bU9h7MZvPJsWPHJpTVfTcqKsp+6623PvXqq6+aqrdz6aWX5tx9993j4+PjtQ35fHJzc0U5Ljdh+ae/hM10mxAY1+iX3XOCKF77u/P2R80QwvsOYfe+QwjdLULobnEse98hxKgZIn/LPiEMt1bd982vhfXaV+qO/8c9ojTiftf4DLnMZS5zuUx6enqLti9cIP8535fqAbTkKz4+Pjo+Pt4eHx8/oMU+QMBDq9VaJ06cuNnf3/+b0aNHnxFCwM3N7dYePXpYe/bseSUA8dxzz80qqz8AgJg3b979ldrQAhAPPPDACiEcCeH48eMPVD6Or6/vXC8vL6HRaMS99977fbUYbvH29rbHx8f/y1mMlRNCAJrIyMglfn5+hXq93m4wGIRGoxHXXHNNVtl2z65du64ICAjINxqN9j59+qQ++uijtwghYDabL+jatetOk8lU4ufnZx8yZMjBOXPmdK/nM6Lm8NNfotR8u2hKQigCJorjR47Wf6yXvnS8KssvEsJ9vBBHTp8ru2uuEE8trrutH/cIESmf//slImpB//zzT0sfQvUc6Hxf7b3LeDKAv2RZ3lFXpbIu4wN11ZFl2Wn3qxCixN/f/0BSUlL/oqIiS2Rk5DoAKC0t/eXo0aO48MILH+3UqRMiIiLKb+BKAoDExMS+lZrpCgD+/v5HygskSaoxYVxYWBg8PDye/OKLL16z2WzfDB48+AZZlgWAhLy8PCkjI+NCAD/W9T48PDzuzMrKumPChAmzgoODZ7366quF3t7eJ+HoVocQogDAzQAQHh4efvr06Z+2bdv2haIo3+bk5PwD4BIAiI6OHrR79+6fQ0JCvoHjCie5MoMH8PgN0Hi4N25/Tz1w4wDgxaXA/z0I7DkBrN4JbJvlvL7d7rhv0VrqmAOxuATQSEBjj09E1Iw8PT3VDsHltNuEUFEUDwCTALxQX11ZlhMBOE34GsJqtX69e/fuFwHoe/XqtQwAhBBpZrM5/ejRo6MvvvhiC4DdZeXJ/v7+e7///vv7AKz88ssv9wYGBi4LDAy0h4eHK/Ud66GHHvryxRdfPLF8+fKlVqt1A4ARAHaZzeaEZcuWzTh9+vShkydPrj927NigwYMHey5atOj7yvu7ubn5ubm5Sb6+vqemT59esmTJkufy8/MjAOQAQFxc3JR+/fqVhoaGfpmVlZVlMBiK3NzcAMDep0+f2f369dswcODAX4qLi1MlSSqVJKm0sZ8bnR8hGjkPYbnJ1yCgKfnYQhm4dwEQdA/gbwLel89NObPlXv27igAAIABJREFUADByBpD/hWN98wHHPITlDBOAy3sCG6c3IQAioubh4eGhdggup90mhABuBGAA8HlLHygvL281gBcvuugiaDSaTeXlHh4eGzIyMm6LiIjYLctyxRW/zMzMEZ6enms/+OCDHyRJ0nTt2jVz+PDhN8qynNCQ46WkpKwICgq67quvvlprtVp/i4+PHzx16tQBWVlZ3yxevHh1SUmJNjAwsESn070GoEpCWFRUpPj4+Nz5zjvvLDSZTAtDQ0NPFRYWngDgBwD5+fldvvvuu0cKCgoUd3d3ERwcnDNo0KA7ZVkufuWVVwb973//m/b5559rDQaD6Nu3b8LAgQPHNcdnSPVr9DyEWg1wxzDAxxMpx441YB7CCc7L/UzA10873za0x7lkEACu6AWIVY2Ll4iohWVlZcHPz0/tMFyK1OSrDkR14xesOfy8F6XjZsMtr/j899W7A3vfAWJCkZGRAX9//+aPj4ioDcnPz4eXV6M7BhuiSTOFqaHdz0NI1F5IjZ125rLuQIxj/kCbzdaMERERtU2ZmZlqh+BymBAStWeeeuCF8RWr+fn5KgZDROQarFar2iG4HCaERG1Eo27vCPZ23M9XJiwsrBkjIiJqm3gurIkJIVEbcd5dxp564Lmbqzzh5NSpU80cFRFR28NzYU1MCInaivO9QugmAbcPrVLk7s55AImIWnhASZvEhJCojTivdFDnDjx8HaCvOtcWp1kgIgK02vY8617jMCEkaiM059NlLAF4ZFSN4tTU1OYLiIiojcrOzlY7BJfDFJmoLejsB2ErheTRwH+yd18JBPvUKPb19W3mwIiI2p6QkBC1Q3A5nJiaWhq/YM0kJSWFJzEiomZw8uRJREZGtuQhODE1EbUMPnuTiKh52O32+it1MEwIidqIrKwstUMgImoX2NtSExNCojYiODhY7RCIiNqF5ORktUNwOUwIidoIPnuTiKh5mM1mtUNwORxlTKQGux1Y+D2Q6eTZwsHegHx1lSeMAHz2JhERtRwmhERqSEyHeOxjSNbSmtsMHkCPcGBojyrFfPYmEVHzyM3NRWBgoNphuBR2GROppbY5BYtKgBkrahTz2ZtERM0jNDRU7RBcDhNCIpXUOQfo5v3AiapPFeGzN4mImkdKSoraIbgcJoRErqjUDry5ukoRn71JRNQ8NBqmP9XxEyFSiVTXs4mtpcAnG4DcwooiPnuTiKh5BAQEqB2Cy2FCSKSS+h8bKYD/+6lijROpEhE1D3YZ18SEkEglUn2PuiwsAeZ8BZQ6RiKnp6e3QlRERO2fj4+P2iG4HCaERCoRqO8KIYBCC7BmFwA+e5OIqLnYbDa1Q3A5TAipQRRFuaJbt25CkqTn1Y6lQ8kvBl5dDqCJXcaZecC42YDnbUCkDHyxufa6QgBPLQb8JzpeTy52lAHAlgP/z959h0dVpX8A/56ZTMlk0iYVCL0TuiAdkSLdVXStKLrq1YVdxHUtK5ZVEVHXXVxclKtrQ7H8FleWLtJFlCYtiPQSICE9mZRJZub8/pgJTDKTBklmknw/zzMPd8499953LjeTN+fccy5gvqvsS0wBlm6/8tiIiOqZ1erjoQBNXLWHLaqqqgHwPYBBAFoqipLsse5eAC8AaAbgAIDpiqLsruVYoapqm48++ujkvn37Ps/Pz7+rqnKiQFbpoBJPv54H9hzH+XCgffv2ldf96xfuf+8oWz7jPde8h6kfAHtPARNfAXq1ARJbee9D/Rb4Zgew7++up6WMeRFoFwc8MtY1WbZ1yeW6mw4Ck+cC4/pU77MQEQUATvTvrSYthI8BKChfqKrqUADvAPg9gEgASwGsUlW10TwoUFVVnRBC588Y7rvvPoMQgi26jUjVg0rcioqBuUuv/Nmb+UXA0h+Bl+8CzMHA0K7Ajf2BxZt91/94E/D4jUBCNNAiyrX80YYK6m4Ebh0EhBivLDYiIj/gRP/eqpVgqKraCcB0AH/2sfohAF8rivKtoig2AG8AsAG4udaivAKPP/747G7duuWZzWZnWFiYLT4+/ishRDAAqKr6VyGEFEIMLa0/ffr0vRqNxuFeP6JTp06yXbt2a7p3754/c+bMYtcuH/9r586dC0wmkzSZTE6LxXJBCNHZ1/EnT54sY2JijgwdOvRiSEiIDA0NLYqNjX2jdL2qqkEzZsx4q1OnTvlms9kZHh5ui4+P/7A08Xzuuef+I4SQkyZN+j4+Pt6xePHiAgCxnseYO3fuexqNximEaA4Av//97/e7P9f9APD222//xWAwlAgh+gPAM888c0+/fv3SIyMjnSEhIfb4+PgfhRBxpft7+eWXRw8dOjQ5KirKYTKZHHFxcYeDgoI6+Pp8b7311rWDBw+2hoeHnxRCxPqqQ7XEKYEVu6FJzbmy7Y+cB7QaoJPHzPy9WgNJZ33XTzrraj28VLeN77oFNuA/24Fp119ZXEREfqLT+bWNJyBVmRC6u4o/APAEAF8TofUCcKl7WFEUCeBnd3lF+8yu4uWjH6v6FixYcPeSJUtevHjx4ncJCQkRjzzyyDMGg+EWs9n8bnX3IYRAcnLyqLS0tDvmzJkT8vTTT6/asmXLs6mpqSsLCwuNTz31VPSQIUP+DN/nBACQmZnZ8ciRIx/fdNNN4ffee++ygoKCx4KCgu4CgJSUlL99+OGH061W69zOnTubHn744Wf0ev3U4ODgFz33sW3btvCioqKWU6dOtQBI81wXHR29olmzZiUARquqaj5x4kTnqKgoe0hIyBQA+PXXX292Op3FAHa/8847Y7788ssPTp8+vV0IYXnyySevb9u2bR+z2bwKAFRVTVy2bNnqQ4cOXXA6nQmzZ8/u3bt37zi9Xr+lfOvonDlzblu0aNHWw4cPH8jNzU2UUl6s7nmly6rdZeymWbDqyg5kLQLCTWXLwkOAvMLq1Q83ucrKt2gu3Q5EhwHXJV5ZXEREfmKxWPwdQsCpTgvhowBSFEX5uoL1oQDKN11kA6iwf0tRlIgqXmcqC8hms93pbqWTJpNJzpo16+SOHTsurT969OjMixcvIiMjY+rhw4dzX3/99TfHjRv3a0FBwV2iBr+FdTrd16mpqcv//Oc/F7Rt29YaFBSEoKCgtq1ater+wgsvZC5fvvwzKWVqJdtnpqWlPfnZZ5/l9urV6/7hw4cjODj4UVVVxd69ex/RaDT7z58//8ru3buLXn/99TdHjRp1Xkr5uzInMjt7RnZ29vmPP/44R0rpKHeIjYmJiUEmk+kmANft37/fdt11120uKSm5bu7cuYaTJ0/2NhgMP0gpnUeOHHn+9OnTMj09/dbMzMzsF154YeuNN974idVq7SuESEhPT39s9+7dQVlZWbdkZWVdmD179oGbbrrpFYfDEQtgQOkB27dvP27hwoWfpqamLs3KyhoipfS6jcBTXl4elytYrnaXMQCUOBBqtfve56RXICOmAhFTgXn/hZz3X9dyxFTYx70ImI1AbkGZbYvSsoDQYN+xmY1AbuHl8txCSLPRdT+hZ/2PN8F2+yDvci5zmctcDvDls2fP1qh+TZcbokoHlaiq2gHA4wD6VVItD0B4ubIIAMevLrSKGQyGigaVAABycnJa6HS63KKiovzSOlFRUUecTmdXADHVOYaUEgUFBUml7xVFOXHixIkHnU7nSydOnNhpNpvtYWFhqy5cuDBVSulzuFJQUNC5oqIi6d6+YOPGjbkOh6MFgOjMzExDUVFRX5PJdCkrkFKipKSkuNxuTlUUo6Ioubt37/518+bN12dmZqakp6frhw8f/v6mTZuu3bVr17RDhw4hPz//awDIyspq43Q6dcHBwUUm0+XWH61W63Q4HK0uXrzYBQCCg4NPe66XrqylJYALQghcvHhxUHFxcaHNZvuTlLLKeVBCQ0O57Gs5o7BmLYSGIKTcPQAJvva5YvblGQ3/+oVr2T2oJAhw3UNodyI0JQ9wb2M8fAFIbOk7tsSWwL5TCL22o6tw3ykId91Ldc6mA5sOwrDokas7D1zmMpe57IfluLi4GtWv6XJDVNUo46FwJVAHVVUFLrco7ldV9VlFURYC2Aegb+kGqqoKAL0BVNSiCFVVqxrv3a2qVsLKhIeHnyspKblGCGEqbcHKyMjoqNFo7E6nMx2AVafTOUtKSkJKt7FarXE+dlUm4Zk3b95HAD5SVVX/yy+/zP7qq6+e0+l0zwB4xlccdru9hRBCSCmlqqqmnJycMK1WexRAemRkZHFwcPDOvLy8ob62rSiG8rp06bLM4XA8uXHjxilGo3FncHDwuh49euiTk5OnnT59WgvgOwCIiIg4o9FoYgoLC02+Erk5c+YcBTCksLAwVkqZVn69qqojpJQwGo0L+vXr97sdO3YcFEL0lVJe8f9TUyelrGpq6su6t4Ij8QpHxYUYgSkDgOe/AN6fDuw9CSzbCfww13f9e0cAf/8fMKGvq/Xvzf8Bf5xQts7iTcDgLkB7Pj2FiBqe4uLybS9UVUL4FdwJhVsCgO0AbgBw2F32HoA1qqp+DGArgJkAjAD+W9FOFUUxX2nA1dGxY8cFMTExH9nt9sWJiYn3TZw48YG1a9d2MZlMS/Ly8pyqqu5q06aNSE1NnTVs2LAt11577RObN2+OAyqeKVhV1c7//ve/p6Wmpi7u0aPH4T59+qRqtVpIKSuc3bKkpMQSExPz6r333jsnPDz8vS1btqCoqGiBoijy/Pnz73z77bfTW7Zs+XRycvL8l156SXfq1Kkp69evLzl16tSSivZZXkhIyJp27do9sWXLllibzTZPUZSMHTt2nPvss88G63S6jKKioqPuc/JS69at/2e1Wr+Kjo7+/dy5c3P27t07bPPmzQOSkpLmxsbGvnnNNdfcderUqf/GxsbePWfOnHMHDhy45qeffhqzc+fO+YsWLQIApKWlpd9xxx09DQbDni1bthwQQvSXUh6p/v8O1ZjZCDx/29U9e3OhAvzuX0Ds/UBUKPCOcnnKma2HgPFzLk8n8/ANwIlUoMdjrvcPjnaVefpkM/DEb648HiIiP8rPz6+6UhNTaUKoKEoBPKaaUVW1tH6KoihWd53vVVWdDldiWDoP4QRFUXLrJuSq/fGPf/z05MmT7desWfPE6dOnc9599117SEjIN1ar9WF3zJsOHjz4/rJly+7fsWNHwaFDh84PGTLk+NmzZ9tVslu90WiclpOT8/S3334rNm7caDebzWvtdvu8ijawWCxHO3Xq9MDSpUuf0mg0xSaT6a38/PzPAKB58+Z/vu+++2wbN26cHRoaOnfu3Lkwm815AF6r4cfd3rVrV8fRo0e1AL4FgM6dOy8vLi5+1Gg0XkrmZ8yYsfbcuXP3rl+//q1jx46lzJw5U2M0GosMBsM69zk5mJKSMnb9+vUfHjp06MTMmTM1BoOhODg4eAeAf3geUFGUUwC6GwyG3WvXrt2r1WoHORyOfTWMu8mrdpdxaDAwoS9STp6sxjyEd/gut4QC3zzte135uQWFAF6/1/WqyOEFlcdBRBTAOA+hN1GjG9up2iZPniw3bty4y2q19vd3LH7GC8yXUxfhTJwJTUEV3RYmAzBvKvDHicjIyEBUVFT9xEdE1IgdP3686j+wr07NppEIAJzomCiQCQD3jwTAZ28SEdUWg8Hg7xACDhNCIj+psstYH+S6f8/smh6Gz94kIqodV/zkp0as2s8ypppZvnx5g2supvpV5ShjjQD+dOOlt7znhYiodqSlpTEpLIcthER+UmkLoRDAqJ5Aq8vTZvLZm0REtYP3Y3tjQkjkJ5UO6DLpgWdvLVPEZ28SEdWOgoJKH7LVJDEhJApErWOBgZ3LFPHZm0REtaOwsIJnuTdhTAiJ/EQ4K2ghDDEAz/3Wqzg1tcLHZhMRUQ3wnmxvHFRC5A+x4SgY0A4h+T6mkmkZDdwy0Ks4MjKyHgIjImr8kpOT63oewgaHE1NTXeMFVoGUlBTEx/NZwERE9e38+fNo3rx5XR6iwc00wi5jIj/R6/X+DoGIqEkymUz+DiHgMCEk8pOsrCx/h0BE1CRlZGT4O4SAw4SQyE/i4uL8HQIRUZMUExNTdaUmhgkhkZ9kZmb6OwQioiYpNzfX3yEEHI4yJqotTidw93zg1MWy5REhwGezAEtomeKSkpJ6DI6IiErZbDZ/hxBwOMqY6lrTucBsJZCmO7znFzTogNm3AM/dVra6zQaDwVCPARIREVAv378cZUzUpPl6PrGtBPjHcqCk7JyDfDYxEZF/8PvXGxNCotpUUYt7iQP46ocyRWazuR4CIiKi8kJCQvwdQsBhQkhUH6xFwMv/VyZhDAriLbxERP7AeWC9MSEkqk2+uoxLJacDPxy+9DY7O7seAiIiovI4D6w3JoREtamyQVr5NmDOfy695WPriIj8g/PAemNCSFSbqhpXtungpWlp0tPT6z4eIiLywnlgvTEhJKpNVU2y43ACby4DADidzrqPh4iIvHAeWG9MCJsoi8XyWo8ePeyqqjb3dyxNSokD+GADkFd49V3GmXnAzfOAkDuB1gqwZEvFdaUEnvoEiLrX9Xryk8vd21sPAea7yr7EFGDp9quLj4goQCUkJPg7hIDTIIc5qqp6B4AZAHoBMCmKUqefIzY2tndwcPCStLS0zna7XWOxWByJiYl7Jk+efOusWbPO1OWxa4PFYjk8cODAmFWrVkWVlmVmZj4F4Ck/htU4CYFqzcX9wXqcn9QV7du3r7ruX79w/3tH2fIZ7wH6ICD1A2DvKWDiK0CvNkBiK+99qN8C3+wA9v3dFeOYF4F2ccAjY4Fh3QDrkst1Nx0EJs8FxvWpOjYiogYoOTm5et+/TUhDbSHMArAQwKy6PpDRaOydnZ29q3nz5vFTp06dPGDAAFNERMT9P/30U48lS5YcVlW1RV3HQA1IdZ78U2AD5n2NsJCrmIcwvwhY+iPw8l2AORgY2hW4sT+weLPv+h9vAh6/EUiIBlpEuZY/2lBB3Y3ArYOAEOOVx0dEFMA4D6y3BpkQKoqyVlGUzwGcqOtjmUymT9u2bau5//77r1VVddXWrVsLDx8+vNjhcEzauXNn8K5du94trdu2bduH4+LiMoODg51hYWHOESNGnFVVNQoAWrdufWOzZs1STCaTw2w2O6+55pp0VVU7CyFGaLVaqarq1NL9WCyW+V27dpWqqiYAgBBC3nDDDbuio6MzjUajbN++feGMGTOeLK3fokWL6bGxsblGo9EZHh7u7Nev34XnnntuCADExsb+Jzs7u/O6dessBoNBxsXFOVVVHeHjGFGtWrX6MTQ01B4WFubs06dP2hNPPDGh9BghISHZY8aMORYfH3/KYDA4mzVrZr///vv/Xdfnv9GyFkG/7sCVb3/kPKDVAJ08evx7tQaSzvqun3TW1Xp4qW4b33ULbMB/tgPTrr/y2IiIAhzngfXWJM6IqqqtAOyvrI6iKBHly4QQwUKIbiNHjjymKMoxz3WFhYXrTSZT7qlTp0YAQFhY2E02m+2dKVOmrGrTps29X3zxhRRC3AagWK/X93I6nd/ceOONe9q3b9//888/z9BoNHcCyAPQrDqf4cCBA9fcdtttf/7+++8Xpaenf/b111/P69y58w8zZ8783mg0WkeOHPmX9u3bf/T++++3OXbs2Jbt27evUlU1+uLFi7f66jJ++umnb/Lcv8Vi2RAWFtblt7/97bgvv/xy77lz5zasXr36fx07dmyvKMppANi3b1/7m2+++aXs7OxXNm3a9PHKlSt/p6rqB4qibKvOZ2gSqttlbC2C4c0VwD2jr+w41iIg3FS2LDwEyCusXv1wk6tMyrJzJy7dDkSHAdclXllcREQNQHZ2NqKioqqu2JRIKRvsa9GiRSMWLVpkr6v9A2gBQE6bNm2Tr/Xh4eEnhwwZ4pRSwmKx7Bk5cqR10aJFQeXrRUVF/adv377ORYsWhfs4xgiNRiMXLVo0tbQsMjJyfpcuXeSiRYsS3HXkLbfccsRjG5NGo3EoirLMV1zBwcGPt2nTRi5atKibe3+Hx48fn+FZx/MYAJoDkI8//vhCj2N0BiCfffbZuVJKmEym7EmTJqV4rE8EIF955ZWnKjuHubm5slSjXy4qlk7NFClxc9UvMUXaJ7xU4T5Lxv5VyvC7pQy/WzoNt0lpuM21HH63lBPnSLnnuHQG31522799I+WkV3zvM+xuad3w86Vy6+Z9Uprv9D7uiNlSPv95YJxPLnOZy1yuo+XU1NQ63b8MgByppq8m0UJ4FTKFENJqtfociVtcXGwJDg7Ody+3iIiISFEUxV6+npSyXVRUVL6iKDlXGkh4ePhpj/0VmEym/Ly8vJYA0KJFi1uklAtzc3Oj7Xa7RkqJvLw8AIip5u5bAkDr1q1/9ig7DgAZGRmdSgtMJpPnxHn5AJCfn1/pn1ihoaFNarnaLYTBeqQ+OAzNK9hP0JoXLu/SY1DJpba8/CIIuxM4eh7o2Ny17b5TQGJL37EltkTIsTTA3RMcciwNSGxZts7ZdARtPQy8/4erPg9c5jKXuRzIy4WFhTWqX+PfBQ1Qk0gI3V3GhyqroyiK1x2mUspCi8Vy+ODBg11UVW2nKMqlexaNRuP1NpstrG3btisBQK/Xn8vOzu6kqqpWURSH536EECcyMjJ6q6oapihKbrnDWJ1OJwoKCsJLCzQaTdvyseTk5LT22J9Jo9GEhIaGnhVC6IOCgr4YP378sXbt2g2cP3/+SZPJ9DiAv+HyNMlVTXh3FgDOnDnT26OsHQBERUUdqWJb8iSrkQwCQLs4lPT1+m+uvhAjMGUA8PwXwPvTgb0ngWU7gR/m+q5/7wjg7/8DJvR1Ja1v/g/444SydRZvAgZ3AdrzCSpE1LhxHlhvDTIhVFVVC0AHQO9+Xzoc0qYoitdvZEVRzgC4oiFFRUVF9544ceKnjz76aOfu3bvv3rVr16b8/PwpOp3u/cTExKJ+/fr9HgDsdvucbdu2/Sc+Pv7rkydP3v/xxx87O3fufNudd975eW5u7px9+/ZNWbt27boTJ05M+fTTT7OaNWt2+0MPPbQGwK9BQUH2jRs3PpqXl/fJBx98cJ3Vah0fE1O2ce+HH37oOH369Ec3btz4Xnx8/KdSSpGYmPgmAL3D4dAajcb8bt26XWjVqlU/nU73rOe2Go0mJTMzs0MFCSmklOejoqL2r1mz5kEASz///PP9MTExX8bExDhbtmypXsl5o0qYjcCztyI6Ovrq9rNQAX73LyD2fiAqFHhHuTzlzNZDwPg5l6eTefgG4EQq0OMx1/sHR7vKPH2yGXjiN1cXExFRA8BHh3prkAkhgHsAfOjxvrTtty2AU7V5oIKCgl1xcXHXnjt37rO9e/eutNvtmsjISEf//v33jh8//lZFUc4CQE5Oztdt2rSZuW7dujm5ubnpBoMBAJIB/Ke4uHhv69atb922bdu7q1atOqvVahEfH58BYJuU8kJCQsKMzZs3v7V27drcjh075rZo0WIDgLGecXTv3n33V1999YLVap3fvHnzonHjxs2eOXPmlpkzZ6JVq1Z/XbNmzexly5YVJiQkFLVo0WJlamrqLaXb5ufnP3P06NG1jz76aPYLL7wgX3zxxZHlP2dmZubokJCQle++++63QghNu3btMkeNGjVFUZRaPZ+NXnW6jA064JZBSDl9qprzEN7hu9wSCnzztO915ecWFAJ4/V7XqyKHF1QdCxFRI3D+/HnOQ1iOkNXt4iK/EULIhx56aIWqqpP9HcsVaDoXmK0E0nQHhLOSjxysB56/DXh6CjIyMjjKjYjID9LS0lC+J66WVfVk+4DTIOchJGrQ3F21drvX+CMiIiK/YEJIVJtEJX8UBmmAu4YBka7bWa1Waz0FRUREnnJzvW6nb/Ia6j2ETYqUssE1PTdZld2CEaQFnrr50ls+XJ2IyD+aN/c5m1yTxhZCotpUWQvhwE5Ax8tfQsnJyfUQEBERlZeSkuLvEAIOE0Ki2lRRC6HZCDx3W5kinU5XDwEREVF5Gg3Tn/J4RojqQ0w4cH33MkUWi8VPwRARNW1XPQ9sI8SEkKg2+WohNOqAZ2/16k5OTU2tp6CIiMgTu4y9cVAJUW3RByHtxSmILS73d5bZCNw93Kt6ZGRkPQVGRESeIiIi/B1CwOHE1FTXmtQFlpKSwkciEREFuNTUVMTFxdXlIRrc7CDsMiaqRXq93t8hEBFRFTgPrDcmhES1KCsry98hEBFRFTgPrDcmhES1qI67IIiIqBZwHlhvTAiJalFmZqa/QyAioipwHlhvHGVMVItKSkq8yjaeceLG/zphl667jBdP0OCWTvxbjIjIXzgPrDf+ViKqRb7uS/nLViesJUCRHbDZgZ/PFfghMiIiKsV5YL0xISSqReXvSzmYJrE/rWwdvY4jkYmI/InzwHpjQkhUi8xmc5n383Y4UewoWycnN6ceIyIiovKKi4v9HULAYUJIVIuCgi7flptWILH0iISj3NTcWo22nqMiIiJP+fn5/g4h4DAhJKpF2dnZl5b/9bPTZ51gU3B9hUNERD5wHkJvTAiJalHpY+tsdon5eySKHN51OEM+EZF/cR5Cb0wIiWpReno6AODLX51w+G4gRHAwWwiJiPzJYDD4O4SAw3kIqdHJLJR4YK0T356SiA4GXh2uwV1dff/tI6XE01uceP+A60a/B3oIvDZcAyFczyUXf7PDFAS43+KOLgLvj634HkCn0wkpJV7eLmH1npIQAOBw+Gg2JCKiehMWFubvEAJOk2khVFV1aGxsrBRC3Oen47dKTEy0R0ZGzvHH8ZuSGeud0GuB1OlafDZRi9+vcyIpXfqsq+6X+OaYxL5pWuyfpsWK4xKL9pWtu2+aFtZHg2B9NKjSZBBwdRlvTQYuVHK/Mke3ERH5V1paWtWVmphqJ4Sqqt6hqupWVVVzVVW1+1g/TFXVPaqqZqqqmuNenlK74V42ePBgqdVqpcFg8Hw5hRCT6uow3vtnAAAgAElEQVSY1aWq6n1CCCmEGFpapijKmaSkpKCsrKxn6+q4Tz/99HwhhAwNDU0XQlxq/VUUZbkQwndG1MjkF7tG9r48RAOzXmBogsCNHQQWH/Ldf/txkhOP99MgIVSgRajA4/01+Cipgr7eajh//jzm/OhAfgWtgwAQHhZ+xfsnIqKrFxUV5e8QAk5NWgizACwEMKuC9b8CuBlAFIAId71PVVXtelURViIyMnKFzWYTHi+NlHJFXR2voZBSWiIjI5/wdxz+cCQL0GqAThZxqaxXjEBSuu/6SelAr9jK6w7/woH4hXZMWebAqZzK8+pMEYGtVdyrzHkIiYj8q6CAT4wqr9oJoaIoaxVF+RzAiQrWX1QU5bSiKBKuR7Y63fvvUCuR1tCrr77adfDgwWdDQ0OdZrO5RFXVJz3X33bbbYfNZnOGZ9ngwYNldHT08tL306dPf7h79+6Z4eHhzuDgYGdMTMxZIUSUqqoJw4YNOx4VFeUwGAwyMjKysE2bNn8DAFVVB7300ksfAIBOp9tqMBhkbGzsSlVV23Tu3FlGRES8Xrr/Bx98cE779u3zTSaTjIyMLGrduvV7QggtcLm1b8KECf+Lj4+3G41GZ7NmzY4LIZpV9dmHDx+eVFBQ8LwQwudNEuU/p6qqI6KioqQQYmrpuQkNDc0aO3bs/oiICKfBYHAmJCR89eSTT97cvXv3HKPRKC0WS15sbOyY6vxf1CdrCRBe7kEg4QYgr9h3Ile+frjBVSalq/7m27U4pWhx+HdaNA8BJn3tgN1ZcVK4MMngNe9geUFa3rpLRORPhYWF/g4h4NT6byZVVbMBhLj3vQXAt5XU3Q+gVSW7m6QoyvdXEEPQ5s2btyQlJenCw8N7TJs2TWzYsGFrRkZG1Ru7zZ0796avvvrqHYPBsCoiIuLeO+64Q+7Zs+e27777rhhAiM1m+yYmJuZfTz311IWkpKRPlyxZ8iej0bihqKhoFYDfPfzwwx+WlJQMk1J+746pjef+X3rppd99+eWXz0RERLzXo0ePx3r37v2npUuXvhQVFXURwOzSert3724jhGjx2GOPdfvqq6/WR0VFLQJwY2Wxm83mP7Ro0WJjTk7O3wE8WO0P7aGgoCAiKSlpafv27a8dNGjQ2+++++4Dn3zyySiDwfDb2bNn79m0adMvP/300+cAoq9k/1dqxBd2bK6gBW5IC2DBSC1yy92il2sDQvXC5zZmHcrUz7W5ykoHlQxv6fpXrwXeGqlB2D8d+CUD6BHjO4YvjulRUkWPs8HI0W1ERP7EeQi91fqgEkVRIgCY4eo+XgXA635Dj7o9FUWJqORVaTKYnZ09yWQyydKXwWAoEUK0AjBgz549UcXFxX9JTk5OeuWVVw7efPPNz5b+kq+OgwcPPp+fn19w/vz5m06fPp352muvZa1bt26RlDJPUZQzO3bsePzw4cMnnnzyycIhQ4bc17NnTxESEnJLdfd/6NChWQ6Hw5qcnPzITz/9VLBo0aI5w4cPP1lUVKR41rt48eIDKSkpqa+++urGnj17ni0pKelb1b7/7//+7/gNN9zw35ycnPvd56PGNBpNyblz55Tdu3cX9ezZ8+8tW7aE3W7fcPr06W+fe+659J49e/4vPz8/SghR6Q1xeXl5tbq86Y4g5D5cCPnnIMg/l11ePakQnSIBuxP4OfnyXH+7zhcjMdr3PhOjgX1p8lL5vjSJLpFOr+O6lq0QApCVxNkrquoRxHm5tXtOuMxlLnOZyzVbPnHiRI3q13S5IaqTUcaKotgURfkGwHW4whaq6oiIiFhRUFAgSl82m00npTwDICErKwtFRUVHPOr+GhoaWu195+bmtjAajSlSSl8DaKJvuOGGHc2aNSs2mUxy1qxZufv370d1unNLWa3WeIPBkCJL+yZdMZ4sKiqKKFf1QumCTqcrdDgcwQBw++237y0dTKPT6byGMPTp0+f3PXv2dEZFRf27ujF5MhgMeVLK0syoQK/Xw263n/Rc716s9KR6nvP6WA7RC0zpKPD63mDkF0tsOyex6nQQ7umm8Vn/3m4a/H2XE7kw47xV4s1dTjzQ09VwnpQucbzQDIdTwlos8dfdJrQwA10tFccwvVMWzLrKzghgDr38vOP6Pj9c5jKXucxlIDw8vEb1a7rcENX1zUxBADpWtFJV1SQArSvZfryiKFuv4LjnIiMjRV5eXicA6wEgOzu7s2f2rtPprA6H41KbsaqqzT0fOxYWFnauqKiokxBCK6Us0+yze/fuDzZs2HBN+/btb0pJSVm1aNEi06JFi3JPnz5dmmA7hRDwyPW8mM3mFJvN1loIIUqTwpycnLZGozG7wo08fPnll70rW68oysWjR4++NX/+/D+dPHlyh+c6dwJ5KSux2WwJDf0vG08LR2vwu7VOxC50ICoYeGeMBonRrtbhrckS45c6YH3Udek/3EvgRI5Aj49d/8UP9hB4uJerbmqBxO/XOZGcB4TogMEtBFZM0UKnrbileXh8CSxGVDgHIQCUlFSykoiI6pzJZPJ3CAGn2gmhqqpaADoAevd7o3uVTVEUqarqLQCOAPjFvd97AIwE8EZF+1QUJfEK467Kj3369Mn48ccfX0lISNh8zz33YPPmzS97JmjNmzffZrPZrmnWrNldf/jDH1YcOHBg8dGjRy/91ZCYmDhn7dq1/4mKivq6devW90+bNs35448/3rZu3brPp02bFq7RaGROTs6Jl156ybRp06YvDh486PnXQUpoaKh0Op09APjs9u7WrdtbK1eufC8hIWHhsGHD/pSYmPjoli1b2hqNxtdq6yR07NjxuaFDhyrbt2+/1rM8Li7uxI4dOwbFxMR0euSRR7Bly5Y3GtNkyZZggW9u8j1f4LAEcSkZBFz3Cr5+nRavX+ddd2QrDX59oGaN6DEx0XhmoMDjm2SFU88wISQi8q+MjAxERJTvkGvaavLb7h4AhQDWAtC6lwtxuYWvGYCvAWQDOA/gdwDuVBRlXa1FW05WVtakcvMQSrPZ/CdFUezDhw+/vmvXrgXZ2dkHFyxYsK+4uPh7z3mHOnbs+Py4ceP2FRQUfDpnzpys77//3tG37+Xb82bPnv317bffPjMsLOy6zMzM9DfeeCNz7969zwLQ9e3b95HevXun5+bmHnz11Vezt2zZYu7du7dnc+CGkSNH7gkKCnrbZDI5Y2Nj/1c+9ueff/7ft91222t6vX7a7t27C7744osXTSbTxxkZGc/V1vlRFKVwxIgRT8E16vuSfv363ZGYmJibn5//61tvvXWwuLh4C38wakdKSgru7aZBZXerch5CIiL/iompYGRgEyYq69YkqgVN6gLLyMhAVFQUntzswD/3SNjKNbxqAMzqloU3J/DLiIjIX5KTk+t6pHH1R7EGiCbz6Dqi+mC3u8Ygzbqm4lZCna6KUSdERFSnbDabv0MIOEwIiWqR1eqa7qa5WWBCO+EzKWRCSETkX5yH0BsTQqJa5Pkl88wADYJ9DNviI5OIiPwrObmKZ4w2QUwIiWqR55fMNfECnSK964SEhNRjREREVB6/h70xISSqReW7g58bpPGaqNpWxHtXiIj8Sa/XV12piWFCSFSLLBZLmfe/6SC8uo3tjgqf5khERPUgKyvL3yEEHCaERLUoNTW1zHutRuDJa11JYbge0GmB6EjOQ0hE5E9xcXH+DiHg1PWj64ialMhI75sGZ12jQa8YCbv7ydCt7GcAtKvfwIiI6JLMzEyYzeaqKzYhTAiJalH5LmMACNIIjGlzeQKalBQ+Q5OIyJ/4CFFv7DImqme8mZmIyL84D6E3JoRE9Yw3MxMR+RfnIfTGhJConvFmZiIi/+L9g96YEBLVs8zMTK+y7CKJ1Hzph2iIiJqeoCAOoSiPCSFRPSt/M7PDKdHtQwc6/5vzExIR1Yfs7Gx/hxBwmCIT1bPyNzMvOyaRYwNKnH4KiIioiYmPj/d3CAGHLYRE9az8zcwvb3eiwA6APcZERPUiPT3d3yEEHCaERPXM82bm3SkSRzjomIioXjmd7JIpjwkhUT3zvJn5lR+dKCy9dVD4rk9ERLWLXcbemBAS1bPSm5nPWyVWn5SXe4rZZUxEVC/Onz/v7xACDhNConpW+pfp/N3OsjkgWwiJiOpFWFiYv0MIOEwIiepZeno6Cksk3tkrYXP4OxoiIiImhNREZRZK3PyNAyHz7Wi9yI4lv1R8g7GUEk9tdiDqbTui3rbjyc0OSOndv/vxQSfE3+x4f3/lNys7nU58csjp3UPMLmMionqRm5vr7xACDuchpCZpxnon9FogdboWey8CE792oFeMQGK0d7+tul/im2MS+6ZpIQCM+T8H2oVLPNL7ct2sIolXdziRGFX1sePi4jH3W4n8knIr2GVMRFQvmjdv7u8QAg5bCP1IVdU7VFXdqqpqrqqqdfqYCiFETJs2bbaFhYWVGAwGGR4e7uzYsWPOE0888XBdHjcQ5RdLLD0i8fIQDcx6gaEJAjd2EFh8yHfL3sdJTjzeT4OEUIEWoQKP99fgo6Sydf+y1YmZfTSIDq76+F/tzURmkY8VbCEkIqoXKSkp/g4h4DAh9K8sAAsBzKrrA1kslu8iIyP73nPPPZMXLFigadGiRRuj0bigpKSkyT2/50gWoNUAnSyXm+R6xQgkVTBPaVI60Cu24ro7LkjsSinbYliZd45ZYC3fOgiwhZCIqJ5oNEx/yuMZ8SNFUdYqivI5gBN1fazc3NyuPXv23Pmvf/1rjaIo8tChQ2cOHDjw7Pz5878srdOqVauJzZo1SzGZTI7o6GjHmDFj9i5YsCAOAGJiYh4PDw93PPPMM9MBQAgRazKZ8m+99dZfVFXV1nX8tclaAoTry5aFG4C8Yt9NdOXrhxtcZVJKOJwS079zYMEoLTSi6ozulwyJ/Rm8U4OIyJ+io6P9HULAYULYgKiq2kpV1ezKXhVtGxYWdmDdunVDR40atfLmm29++MUXX7R4rtdqtYkpKSnLRowYsf/JJ5+MNhgM1/z444/tt27dugEA0tLS3tTr9eu//vrrf7722ms9LBbLhu7du2tuuOGG6xVFqXCsbF5eXr0vj/jCDvE3369Bn9pg1gG5xWW3Tcu1IVQvfO6zfP1cG2DWSQghsHCvRNcIOwY1d23rcDjKbFt+efVJJ5w+BqQAgGexP84bl7nMZS43leUzZ87U6f4bIuFrtCTVL1VVRwD4TlGUOms6EkKYO3Xq9K/c3NxJ6enpFp1Oh169eiWPGzfuNy+88MKe6OjoLzt16nTLfffdF6Ioig0AQkNDn0tISHjpsccea6koSrIQwhQWFnYqJCQkDIBuxowZk2bPnr26ikMH3AWWXywR+bYDSfdr0THSlcjdu8qB5mZg3nDvxs7BS+y4v7sGD/V0/f30wQEn1P1O/Hh3EG76xoHNZyUM7s0yi4DgIOCebgJvj/be16kciS4f2GFzeLcm6jQSxX/S1eInJSIiXzIyMhAVFVWXh2hwNwGx76qJkFJaAUwDACGEvkOHDg/s2bNnQVhY2AZVVSOllB127dql3bt3b9GsWa5bGp1OJ7KzsyWAVgCSpZQFkZGRb1+4cOHFW2+99ddqJIMBKUQvMKWjwPPbnHj/Bg32pgHLjkn8cJfvnu97u2nw911OTGgrIATw5i4n/tjHlRx+NE6DIo/20SnLHLi1kwYP9PD9XdAmXGBAdBG2pFZj9AkREdUJu71Ox3E2SEwIGxBVVVsBOFRZHUVRzFXtR0pZDOCd6OjoqSkpKYMBRAohTg4cOLDH1KlTjYqi+BxuazAYugJ4rk+fPifWrFnT8emnn35s3rx5/7iSz+JvC0dr8Lu1TsQudCAqGHhnjObSlDNbkyXGL3XA+qjrx+PhXgIncgR6fOzK/B7sIfBwL1fdCGPZxE+vAcL0QLih4j8OZ3azYndmsPe0MwHXlkpE1DhZrVbExcX5O4yAwi5jP3IPxtABGA5gFYDSZM6mKEqt/sd06NBhbd++fTfGxcUtfvvtty907NjxljNnznw2ZsyYzOXLl8fr9foeWq12z29+85s1bdu2fXDevHkZPXr0GNC2bdsbli1b9oK7u/jkgAEDNLfeemub2bNnfxUZGTl2+vTpfWfNmrW/kkPzAivHas1Hvy8N+DWrbDm7jImI6ofNZoPBYKjLQzS4LmMOKvGvewAUAlgLQOteLgTQurYPVFJSUrxx48Zn33vvvbNGo9GRk5OzZODAgYdGjx49GACKi4sPxMbGTty6dWvvf/7zn+dNJlNJVlbWep1ONwgAoqOjl8bFxUVNnjz5ekVR8tPT029NTU1NX7ly5XpVVUNqO97GLDU1Bc8NEjCXz/2YOhMR1Yvk5GR/hxBw2EJIdY0XWDkZGRkIjbAgfqEDWbbL5WwhJCKqH2fOnEGrVq3q8hBsISSiytntdui1Ao9dI2BsUDM4EhE1DhaLpepKTQwTQqJ6ZrVaAQDT+5T78WNbKhFRvUhNTfV3CAGHCSFRPUtISAAARAUL3NZZQFvasdDgOhiIiBqmyMhIf4cQcJgQEtUzz5uZnx6ggZ7dxkRE9aq4uNjfIQQcJoRE9UynuzxwpGuUQN/SqbDYZUxEVC/y8/P9HULAYUJIVM/K38z83EANgoPALmMionpSeusOXcaEkKielb+Z+YY2Ai1DgQido4ItiIioNnEeQm98dB1RPSt/M7MQAgfv0+JcSjqAeP8ERUTUhNTxU0oaJLYQEtUzX/Nf6bQCYcF6P0RDRNT0hIWF+TuEgMOEkChAZGVlVV2JiIiuWlpamr9DCDhMCIkCRFxcXNWViIjoqkVFRfk7hIDDhJAoQGRmZvo7BCKiJqGgoMDfIQQcJoREAaLAVoLj2ZyMkIiorhUWFvo7hIDDhJAoQHx4riU6vM+pZ4iI6hrnIfTGhJAoQCRd4F+sRET1gfMQemNCSBQgCqSu6kpERHTVgoOD/R1CwGFCSBQgrHb+OBIR1QeTyeTvEAIOfwMRBYjMQqe/QyAiahIyMjL8HULAYUJIFCDyHewyJiKqDzExMf4OIeAwISQKELk2TjlDRFQfcnNz/R1CwGFCSBQgChz8cSQiqg82m83fIQQc/gYCMHLkyFlarbZemmeGDh2qRkRE2A0Ggxw+fPgb9XFM8o/MQombv3EgZL4drRfZseSXqu8RNAWxlZCIqK5xHkJvAZ8Q9u3b93uLxVJiNBplaGios1OnTsnjxo0beKX7GzJkyPtRUVHFtRljdU2aNMmwc+fOh3r37v2SzWYTW7ZseeJq99mtW7djiYmJh2sjPqpdM9Y7odcCqdO1+GyiFr9f50RSeuUJX7CWA0uIiOoa5yH0FvAJYUxMzCuDBg1qV1RUJIYPHx5jMplSk5KSvvV3XFWZNGmS1yRHDoejR3FxMYKDg1f5I6aK+IqVrk5+scTSIxIvD9HArBcYmiBwYweBxYcqT/jMHFdCRFTnQkJC/B1CwAn4hHDt2rWrV65cedb9VgPAmZmZaa5sm0GDBi2JiYkpDg4OlgkJCXmjRo2aAQCjRo16aMeOHQ9kZWXpDAaDNBgMcuTIkbNKtxs2bNj8qKiokuDgYNm5c+ezEydObFa6bsKECR0SExN/jYiIsJvNZmfnzp3Pjh8/PrF0vcVisffr129969atswwGg8zJyZnnGdOoUaMe2rBhw04A2LBhw06DwSAnTZoUOmnSJEP//v3XRkdHF5tMJtmyZcvcMWPG3F263fXXX//nhIQEq8lkcprNZmeXLl1OT5gwoRsAXHvttSt//fXX9ocPH+5c+nkmT56s69ev36a2bduWGVPfunXr7P79+68DLneRDx069F2LxVLy3XffFQDAxIkTo3r37r3TYrGUhISEONu1a5c2duzYkR7n563Y2Fibu7XW0a1bt2PV+19seo5kAVoN0MkiLpX1ihFISq98OxMTQiKiOqfX6/0dQsAJ8ncA1TFs2LC3d+3aNaOoqAgajQb9+/f/TyV1Fxw4cOCOgQMHPmg0Gj/Lysp69/vvv3973LhxP69fv/69IUOGDDh8+PC9GRkZl66GkSNHznI6ncjMzBw/cODABKfTGb1z586fw8LCPgZww+TJk8XBgwd3h4aGXhgyZEhbAAWnTp364ZdfftkKwFK6n2PHjl3Xv3//qT179vxSShnhGdf69evfGzdu3C9r167dOnLkyP6rV6/eBQB9+/bddvHixV79+vUbo9PpfsjMzFS3b9++eMKECdtWrVp1SqPR5Hfp0mWG0Wj8wuFwdEpKStp64sSJ1QBa79ixY2K3bt2OCSHsSUlJXUqP1a9fvyrPqdPpRHp6+rhBgwa1A1AAAMePH99tt9uDBwwY0Fur1Z66cOHCyj179qyeNGlShJTS9MMPP8y87rrrHt+wYcPfJ06cGFNUVHRbdf8PmxprCRBe7vsm3ADkFfvuMnY4XeV62AEY6jg6IqKmLSsrCxaLpeqKTUjAtxACwNatW/9QWFgoxo0b17Nv377rTCbTtorqJicn39mpU6cfvvvuuw9WrFhh27Zt2/0xMTHWjIyM56s6TuvWrX+zcuXK1NWrVyclJCTszc7O7g4AhYWFU1NSUsLatm3bf+XKlWdXrlyZ0bp164mnT5+OHD9+/KXsq0OHDpvXrVv3xfLly+WKFSuyqjre5MmTxaFDhwZ36tTp6TVr1mxevnx5ybZt2+4PCQkpzs3NfRIA1q9f/85333338YoVK2yrV68+0K5du7fOnTvXsnpnrnJt2rS5o/TzTJgwodOvv/7aukOHDr9ZvXp10ooVK/KbN28+ymq16gsLC+8DAK1Wi8LCwmsnTJjQbuXKlWnr16//V1XHyMvLa5TLwz6zQfzN7vM19HM7zDog1yP5y8vLQ64NCNULn/sscfckG/S6gPmMXOYyl7ncWJfNZnON6td0uUGSUjao1/jx47vp9Xo5fvz4dr7Wx8TE2AYPHvyhZ1mXLl1OdO/e/aCUEoMHD37fYrEUe66//vrrZ2k0GulZds0112xq06ZNhpQSw4YNe1MIIYODg8u8dDqdHDlypCKlRGRkpH3IkCGLKot97NixQwHIcePG9XN/li4ApNFoLLNfvV4v+/fvv1pKidGjR9/dtm3b9NDQUEdpt7Drv821z65dux7r1q3b4YpiL321atUqu1+/futKP68QQk6aNEmUrh81atQ0AD4/49ChQxeUbte+ffuU4OBgZ7NmzfKHDh36djX+z5okq80pdW+WyCOZzktl96y0y6c2233WdzqdEm+UyO7v5ddXiERETdbp06fr+hB+z5dq+moQLYSepJSG4uJi2O32nr7Wh4SE5BUWFnbwLLNardFGozEZAIQQjpoeU6/XH9Dr9Rg1alRQQUGBKH0VFxeL9evXqx5Va7RvrVb7q16vx5AhQ+7z3K/NZhM7duwYDwA///zzhxEREUeGDRvWqqioSAwcOPAlz30IIbxGKWi12rySkpIyHZb5+fllHtwohMDy5csvNWHp9fqdADBixIiu5T/j1q1b/wgAGzZsmH/s2LH4UaNGGTp27Lhg27ZtM8aOHXt9TT5zUxGiF5jSUeD5bU7kF0tsOyex7JjEPd18/8gJ4brXMN8ufK4nIqLaU1JS4u8QAk5AJ4STJ0/WDho06KvSQRTjx4/vd+zYsZWRkZF2vV6/2tc2CQkJXxw5cmTI6NGj75s0aZJhyJAh76empoZGRUXNAQCdTncyPz9fN3HixBbVjSM4OHhxbGxszunTp/dMmDChAwBMmDChy7Bhw966ms+3fPlymZiYuO3o0aNvjR07djQATJw4Me76669/Zvz48X0AwGazaYOCgnI0Gs35cePGDTxx4sQsz30YDIa0/Pz82MmTJ2tLy0JCQtanpqaax4wZc/ekSZMMgwYN+iorK6vS4QqrVq061KVLl1PHjx9fN378+GvcsbS+7rrr5k2cODFu/PjxicOHD39j4sSJLZcvX16i1WpTAUAIwZ+qCiwcrUGhHYhd6MCdKxx4Z4wGidGVJ3zFskHc1ktE1KBxHkJvAf/b5+LFiyMOHjx40GAwCKPR6GzevPmZ/v3737BixQqf04xv3br1D4MGDYrdu3evmp+f/6HFYskfOnToY2vWrPkeAEJCQv7RqlWrP27atOmsyWQSAwcOfLSqGJYvX+6YMGFC3+Tk5GU//vjjYaPRqDWZTPYWLVocudrP17x581E6ne6rn3/+eaXRaNTr9XpnXFxcaocOHb4FgL59+847ePDgE/v27XNGRUUVtGrVas3Zs2enlG4fGxv7zMWLF1euX7++xGQyiVGjRuk3bNgwv2/fvr/dvn37YgCLO3fu/H1CQkJOVbG0a9eu34ULF77ZuXPndqPRqDMajY74+Phks9n8JoCgM2fOPHDx4sXHjUajCAsLKx48ePCi0vNK3izBAt/cpK26ooe8Ys5DSERU15KTk9G+fXt/hxFQhJR8MgLVKV5g1ST+ZkeQkCh5nHPPEBHVpdTUVMTFxdXlIRrc/T8B3WVM1JToNBJ22eC+Q4iIGpygoIDvIK13TAiJAkQIH1tHRFQvsrOz/R1CwGFCSBQgIoP540hEVB/i4+P9HULA4W8gogBhEsX+DoGIqElIT6/iOaJNEBNCogARzifWERHVC6eTt+iUx4SQKEBYTLzJmYioPrDL2BsTQqIAoXcW+jsEIqIm4fz58/4OIeCwSYIoQPy+F9AmohBAqL9DISJq1MLCwvwdQsBhQkgUIEZ3jkAvSxqYEBIRUX1jlzFRAMnNzfV3CEREjR6/a73x0XVU13iB1UBhYSGCg4P9HQYRUaNWD9+1De6xU2whJAogKSkp/g6BiKjR43etNyaERAFEo+GPJBFRXeN3rTeeEaIAEh0d7e8QiIgaPX7XemNCSBRA2I1BRFT3+F3rjQkhUQCJiIjwdwhERI0ev2u9MSEkCiB2u93fIRARNXr8rvXGhJAogFitVn+HQETU6PG71hvnIaS6xgusBrZlUXAAAArASURBVGw2GwwGg7/DICJq1Orhu5bzEBLRlUtOTvZ3CEREjR6/a70xISQKIDqdzt8hEBE1evyu9caEkCiAWCwWf4dARNTo8bvWGxNCogCSmprq7xCIiBo9ftd6C/J3ANS4CSFKAGj9HYebQOAPcgnkGAM5toaA5+/K8dxdHZ6/q3Ml569YSqmvi2DqCkcZU5MhhNglpezn7zgqI4TIl1KG+DsOXxrC+QtkPH9Xjufu6vD8XZ2mcv7YZUxERETUxDEhJCIiImrimBBSU6L6O4Bq+NrfAVSiIZy/QMbzd+V47q4Oz9/VaRLnj/cQEhERETVxbCEkIiIiauKYEBIRERE1cUwIiYiIiJo4JoTUKAghtEKIN4QQaUKIPCHEUiFEdAV1RwghpBDC6vH6ob5jDiRCiDuEEFuFELlCCHs16vcTQuwQQhQIIY4LIabWR5yBqibnTwjRxn395Xtcf8n1FWugEUK8JoRIcp+780KI94QQlT5XTAgxzr1NoRDioBDihvqKN9DU9Pzx+8+bEOIVIcRJ9zm8KIT4jxCiVSX1G+X1x4SQGounAfwGwAAACe6yxZXUd0gpzR6vwXUeYWDLArAQwKyqKgohwgGsBrAUQCSARwC8K4QYVKcRBrZqnz8PnT2uv4SqqzdaDgBTAUQB6AXXz++HFVUWQrSDazT+qwDC3f/+VwjRpq4DDVA1On+l2/D7r4zFAHpLKcMAtAFwBsAXvio25uuPCSE1FgqA16SUJ6SUOQCeBDCuMfyQ1gcp5Vop5ecATlSj+hQAhQBel1LapJTrAPwXrv+DJqmG5488SCmfkVL+LKUskVKmAXgbwIhKNpkGYLeU8lMpZbGU8jMAe9zlTc4VnD8qR0p52P17A3A9ps4JoHMF1Rvt9ceEkBo8d4tVKwC7S8uklMcB5ALoWcFmWiHEWSFEihBipRCiVz2E2lj0ArBHlp2zao+7nKrvJ/ctDpuEECP8HUwAGQVgfyXre8HjZ92N199lVZ0/gN9/XoQQdwkhcgBYATwK4K8VVG201x8TQmoMwtz/5pQrz/ZY5+kwgN4A2gLoAteX5wYhRPM6i7BxCUX1zzV5SwcwCK7rrw1cXe+rhRAV/fHSZAghbgHwEFy/kCvC668C1Tx//P7zQUq5REoZDqAZXMnggQqqNtrrjwkhNQZ57n/Dy5VHwNVKWIaUMkVKuU9KaZdSZksp/wIgE8D4Oo6zschDNc81eZNSWqWUP7q7m/KllAsAfA/gt/6OzZ+EEL8F8B6AG6WUeyqpyuvPh+qeP37/VU5KmQLXeVxRweCcRnv9MSGkBk9KmQ3XTcB9S8vcN/6Goequk1JOuO4doartA9CnXFkfdzldmSZ9/Qkh7gewCMBkKeXGKqrvg8fPuluTvv5qeP58adLXnw9BAEIA+Go1bbTXHxNCaixUAE8JIdoKIcIAvAZgrZTyVPmKQoiRQogOQgiNEMIshPgrgDgAa+s14gDinrbHCEDvfm90v3z9kvgvAJMQ4gkhhF4IMQqugSZN4nmfvtTk/AkhBgohugshgtx1FADXwXVemxwhxEwAfwMwVkq5rRqbfAKgnxDiTiGETghxJ4BrAHxcl3EGqpqeP37/leU+D38QQsS63ycA+BeAU3B1r5fXaK8/JoTUWMwDsBzATgDnAGjhmooBQoi7hRBWj7q9AKyHq+n/BICBAMZIKc/Wa8SB5R64Rg6vhevcFbpfrYUQw9xzlbUCLrXIToCrizMHru6VR6SU2/0SeWCo9vmD696tb+A6d+fc206WUpa/Ub2peAuu1vyNnnPjla4s//PrHjA2BcCzcHXTPQvgZl9//DURNTp/4PefLxMAHBRC5AP4CUABgNFSSntTuv5E2YGCRERERNTUsIWQiIiIqIljQkhERETUxDEhJCIiImrimBASERERNXFMCImIiIiaOCaERERERE1ckL8DIGrshBASrnmt5kspZ3uUxwBYAqAfgK8BXASQKqWcX8397gBwv5QyyaNsA4DBAHZJKYfW1mdQVdUC4N8AboDrWbx/URRlSSX1reWKggEsVBTlj6qqboJr7jO7e905RVE6e2zbFa6JYa8BkAbgCUVRmuSkzURE9YUJIVEtEEJEwvU80Pxyq0oTwF5SymPl1v0FwFEp5Rh3crgXQAePfbaH69F7HaSUF9xldwN4A8AAuJ5O8BKAW0q3kVKOFELcB+DBWvpopf4FoBiuJxr0BrBSVdV9iqIk+aqsKIq5dFlV1RAAqQD+z6PKHxRFeb/8dqqqBgFYBuBdAGPgeoLHclVV+yiKcqS2PgwREZXFLmOi2tEbQKaU0lzu9VYl24zG5STpPgCrpJSFpSvdM+KvADALAIQQgwC8DeAm91MF/gfgeiFEs9r/OJe5E7pbADynKIpVUZTv3ce+p5q7uBWu1s+t1ajbBa7nh/5DURSHoigbAGyrwbGIiOgKsIWQqHb0BnCoOhWFEHq4ukLDACwXQpx0v//AR/XXAGwQQiyGq1v5ESnlDgCQUhYJIXbD1Y1bo+doqqq6AkBFXcrfK4oyyeN9JwCOci10++BqvauOaQA+URTF87FIr6qqOg/ArwBmK4qyyV3u69nJAkD3ah6LiIiuABNCotrRB9VMCKWUxe7Wvo1SyjgAEEKkwZUcla+7x32v4E8AXpNSflmuyi9wPZu0RsolfFUxw/XcXU85AEKr2lBV1VZwJY4PeBQ/Bde5KgZwB1xdwr0VRTkO18PkLwJ4QlXVfwC43r39xhrES0RENcSEkKh29AbQQQhxu0fZB1LKP1VSf5/H+wi4HjZfhhBCA8ABwAlXa2F5eQDqtMsYgBWu1kxPYfARrw/3wtXieLK0QFGUnzzWf6yq6p1wPVx+gaIoJaqq3gRgAVyJ4y4AXwGwXUX8RERUBSaERFdJCGEA0BXAICnlrmpuVj4hzILvFrc34UoWjwK4G97dyqEAsmsUMABVVVcDGFbB6q2Kooz3eH8EQJCqqh0VRTnqLusFwOeAknLuBTCvijoSHl3FiqLsh0d3tKqqP6CGXeJERFQzTAiJrl53uJKaAzXYpheAxR7v98N1r97O0gIhxMMAboZrRPEIAH8VQnwopfS8F68rgE9rGnC5hK+quvmqqn4N4CVVVR+EK5n9DVzT21RIVdXBAFrAY3SxqqoRcH2ezXBNO3M7gOFwD5xx1+kJVxKqATAdrhbQj6obLxER1RxHGRNdvf9v715VMgjCOIw/E9RiNBgEk1mMZjUKIhgET6AMHvAGBJt4AWLaG7CIUYPVolkvwCSKxSYYXsPuB/sZxM9DcZ5f22GWmfhnDu9MAHcR0cu25jjdK4TntFbFUkrTwCEwGxGPwCnQTx3EOn0GqGv1XX5/6l+2TV1L8Ak4AbbaJWeqqrqoqmrvwz+rwFnOub213AccUF+ieQZ2gbmcc/v85DLw0Iw1BczknN0ylqQ/lLoXGyT1KqV0DGwCr63mAEYi4qUpTD3WqUOYUhoG7oHBiHhr2oao6xCOAaPAFbASEeetcXaApYiYbL4XgMWImP8wnzVg4zcLU0uS/jcDofTHUkqv1JcijiJi/5N+h8BTDy+VXAPrEXHbarukfgXkJiKmfjZzSVIpDISSJEmF8wyhJElS4QyEkiRJhTMQSpIkFc5AKEmSVDgDoSRJUuEMhJIkSYUzEEqSJBXOQChJklS4dzuFhChwHrKyAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 576x468 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the variational index\n",
    "shap.plots.waterfall(coff[3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "18ddd0ad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[14:03:26] WARNING: /tmp/build/80754af9/xgboost-split_1619724447847/work/src/learner.cc:1061: Starting in XGBoost 1.3.0, the default evaluation metric used with the objective 'binary:logistic' was changed from 'error' to 'logloss'. Explicitly set eval_metric if you'd like to restore the old behavior.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch:  72%|███████▏  | 86/120 [00:00<00:00, 421.98it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=0;diff=0.0066854854354721225;time=0.00228095\n",
      "iter=1;diff=0.0003328552254797111;time=0.00218272\n",
      "iter=2;diff=1.6839918845817892e-05;time=0.00215960\n",
      "iter=3;diff=8.717954203498396e-07;time=0.00213981\n",
      "iter=4;diff=4.5111714587496105e-08;time=0.00215912\n",
      "iter=5;diff=2.3555543941463898e-09;time=0.00214839\n",
      "iter=6;diff=1.227666657953371e-10;time=0.00286293\n",
      "iter=7;diff=6.425048332758437e-12;time=0.00215077\n",
      "iter=8;diff=3.3574583048517037e-13;time=0.00213933\n",
      "iter=9;diff=1.759564795811643e-14;time=0.00215316\n",
      "iter=10;diff=9.25636772073513e-16;time=0.00215101\n",
      "iter=11;diff=5.354900274493028e-17;time=0.00269914\n",
      "iter=12;diff=4.625929269271485e-18;time=0.00214386\n",
      "iter=13;diff=0.0;time=0.00214481\n",
      "iter=14;diff=0.0;time=0.00216794\n",
      "iter=15;diff=0.0;time=0.00214767\n",
      "iter=16;diff=0.0;time=0.00253105\n",
      "iter=17;diff=0.0;time=0.00214648\n",
      "iter=18;diff=0.0;time=0.00213361\n",
      "iter=19;diff=0.0;time=0.00215530\n",
      "iter=20;diff=0.0;time=0.00248837\n",
      "iter=21;diff=0.0;time=0.00253510\n",
      "iter=22;diff=0.0;time=0.00215364\n",
      "iter=23;diff=0.0;time=0.00213695\n",
      "iter=24;diff=0.0;time=0.00214624\n",
      "iter=25;diff=0.0;time=0.00213504\n",
      "iter=26;diff=0.0;time=0.00256062\n",
      "iter=27;diff=0.0;time=0.00214815\n",
      "iter=28;diff=0.0;time=0.00213957\n",
      "iter=29;diff=0.0;time=0.00215077\n",
      "iter=30;diff=0.0;time=0.00214148\n",
      "iter=31;diff=0.0;time=0.00237966\n",
      "iter=32;diff=0.0;time=0.00218391\n",
      "iter=33;diff=0.0;time=0.00220823\n",
      "iter=34;diff=0.0;time=0.00214958\n",
      "iter=35;diff=0.0;time=0.00212836\n",
      "iter=36;diff=0.0;time=0.00212836\n",
      "iter=37;diff=0.0;time=0.00230885\n",
      "iter=38;diff=0.0;time=0.00216389\n",
      "iter=39;diff=0.0;time=0.00213933\n",
      "iter=40;diff=0.0;time=0.00213075\n",
      "iter=41;diff=0.0;time=0.00213385\n",
      "iter=42;diff=0.0;time=0.00230813\n",
      "iter=43;diff=0.0;time=0.00221467\n",
      "iter=44;diff=0.0;time=0.00243950\n",
      "iter=45;diff=0.0;time=0.00231171\n",
      "iter=46;diff=0.0;time=0.00228000\n",
      "iter=47;diff=0.0;time=0.00230336\n",
      "iter=48;diff=0.0;time=0.00227857\n",
      "iter=49;diff=0.0;time=0.00213742\n",
      "iter=50;diff=0.0;time=0.00214386\n",
      "iter=51;diff=0.0;time=0.00213099\n",
      "iter=52;diff=0.0;time=0.00214338\n",
      "iter=53;diff=0.0;time=0.00260162\n",
      "iter=54;diff=0.0;time=0.00215435\n",
      "iter=55;diff=0.0;time=0.00213170\n",
      "iter=56;diff=0.0;time=0.00215960\n",
      "iter=57;diff=0.0;time=0.00214171\n",
      "iter=58;diff=0.0;time=0.00213099\n",
      "iter=59;diff=0.0;time=0.00231671\n",
      "iter=60;diff=0.0;time=0.00283670\n",
      "iter=61;diff=0.0;time=0.00213885\n",
      "iter=62;diff=0.0;time=0.00238347\n",
      "iter=63;diff=0.0;time=0.00213146\n",
      "iter=64;diff=0.0;time=0.00213981\n",
      "iter=65;diff=0.0;time=0.00211835\n",
      "iter=66;diff=0.0;time=0.00216889\n",
      "iter=67;diff=0.0;time=0.00212240\n",
      "iter=68;diff=0.0;time=0.00214100\n",
      "iter=69;diff=0.0;time=0.00213528\n",
      "iter=70;diff=0.0;time=0.00212932\n",
      "iter=71;diff=0.0;time=0.00214672\n",
      "iter=72;diff=0.0;time=0.00212479\n",
      "iter=73;diff=0.0;time=0.00213861\n",
      "iter=74;diff=0.0;time=0.00324178\n",
      "iter=75;diff=0.0;time=0.00212622\n",
      "iter=76;diff=0.0;time=0.00239921\n",
      "iter=77;diff=0.0;time=0.00214720\n",
      "iter=78;diff=0.0;time=0.00215673\n",
      "iter=79;diff=0.0;time=0.00214124\n",
      "iter=80;diff=0.0;time=0.00214505\n",
      "iter=81;diff=0.0;time=0.00215554\n",
      "iter=82;diff=0.0;time=0.00213337\n",
      "iter=83;diff=0.0;time=0.00214720\n",
      "iter=84;diff=0.0;time=0.00282049\n",
      "iter=85;diff=0.0;time=0.00212431\n",
      "iter=86;diff=0.0;time=0.00216937\n",
      "iter=87;diff=0.0;time=0.00215125\n",
      "iter=88;diff=0.0;time=0.00215292\n",
      "iter=89;diff=0.0;time=0.00213361\n",
      "iter=90;diff=0.0;time=0.00215220\n",
      "iter=91;diff=0.0;time=0.00214314\n",
      "iter=92;diff=0.0;time=0.00212479\n",
      "iter=93;diff=0.0;time=0.00214767\n",
      "iter=94;diff=0.0;time=0.00213671\n",
      "iter=95;diff=0.0;time=0.00214219\n",
      "iter=96;diff=0.0;time=0.00241899\n",
      "iter=97;diff=0.0;time=0.00214696\n",
      "iter=98;diff=0.0;time=0.00214672\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 426.74it/s]\n",
      "Epoch:  38%|███▊      | 45/120 [00:00<00:00, 438.06it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=99;diff=0.0;time=0.00247216\n",
      "iter=100;diff=0.0;time=0.00214744\n",
      "iter=101;diff=0.0;time=0.00213432\n",
      "iter=102;diff=0.0;time=0.00214934\n",
      "iter=103;diff=0.0;time=0.00213122\n",
      "iter=104;diff=0.0;time=0.00215149\n",
      "iter=105;diff=0.0;time=0.00215030\n",
      "iter=106;diff=0.0;time=0.00212598\n",
      "iter=107;diff=0.0;time=0.00214648\n",
      "iter=108;diff=0.0;time=0.00212526\n",
      "iter=109;diff=0.0;time=0.00214911\n",
      "iter=110;diff=0.0;time=0.00212693\n",
      "iter=111;diff=0.0;time=0.00215006\n",
      "iter=112;diff=0.0;time=0.00212979\n",
      "iter=113;diff=0.0;time=0.00214958\n",
      "iter=114;diff=0.0;time=0.00214958\n",
      "iter=115;diff=0.0;time=0.00212383\n",
      "iter=116;diff=0.0;time=0.00214195\n",
      "iter=117;diff=0.0;time=0.00212359\n",
      "iter=118;diff=0.0;time=0.00218129\n",
      "iter=119;diff=0.0;time=0.00213623\n",
      "iter=0;diff=0.00668548546996382;time=0.00225592\n",
      "iter=1;diff=0.0003404728496326679;time=0.00233531\n",
      "iter=2;diff=1.8374447994704888e-05;time=0.00214934\n",
      "iter=3;diff=1.0173018864558342e-06;time=0.00211358\n",
      "iter=4;diff=5.638581237711529e-08;time=0.00212836\n",
      "iter=5;diff=3.1498237269663714e-09;time=0.00210834\n",
      "iter=6;diff=1.7572916152933084e-10;time=0.00213051\n",
      "iter=7;diff=9.832962889760715e-12;time=0.00210547\n",
      "iter=8;diff=5.496176582265042e-13;time=0.00212526\n",
      "iter=9;diff=3.075495176925896e-14;time=0.00214624\n",
      "iter=10;diff=1.7259242294382838e-15;time=0.00213361\n",
      "iter=11;diff=1.0113766818973361e-16;time=0.00213146\n",
      "iter=12;diff=8.012344526598183e-18;time=0.00214624\n",
      "iter=13;diff=0.0;time=0.00218582\n",
      "iter=14;diff=0.0;time=0.00211358\n",
      "iter=15;diff=0.0;time=0.00212097\n",
      "iter=16;diff=0.0;time=0.00234747\n",
      "iter=17;diff=0.0;time=0.00211549\n",
      "iter=18;diff=0.0;time=0.00214958\n",
      "iter=19;diff=0.0;time=0.00211549\n",
      "iter=20;diff=0.0;time=0.00211716\n",
      "iter=21;diff=0.0;time=0.00211787\n",
      "iter=22;diff=0.0;time=0.00212455\n",
      "iter=23;diff=0.0;time=0.00212193\n",
      "iter=24;diff=0.0;time=0.00213075\n",
      "iter=25;diff=0.0;time=0.00210738\n",
      "iter=26;diff=0.0;time=0.00212312\n",
      "iter=27;diff=0.0;time=0.00213599\n",
      "iter=28;diff=0.0;time=0.00211859\n",
      "iter=29;diff=0.0;time=0.00212097\n",
      "iter=30;diff=0.0;time=0.00210118\n",
      "iter=31;diff=0.0;time=0.00212193\n",
      "iter=32;diff=0.0;time=0.00210047\n",
      "iter=33;diff=0.0;time=0.00212169\n",
      "iter=34;diff=0.0;time=0.00210714\n",
      "iter=35;diff=0.0;time=0.00211549\n",
      "iter=36;diff=0.0;time=0.00219226\n",
      "iter=37;diff=0.0;time=0.00211620\n",
      "iter=38;diff=0.0;time=0.00216842\n",
      "iter=39;diff=0.0;time=0.00212717\n",
      "iter=40;diff=0.0;time=0.00211239\n",
      "iter=41;diff=0.0;time=0.00211430\n",
      "iter=42;diff=0.0;time=0.00211334\n",
      "iter=43;diff=0.0;time=0.00214434\n",
      "iter=44;diff=0.0;time=0.00280094\n",
      "iter=45;diff=0.0;time=0.00215292\n",
      "iter=46;diff=0.0;time=0.00213671\n",
      "iter=47;diff=0.0;time=0.00212121\n",
      "iter=48;diff=0.0;time=0.00212240\n",
      "iter=49;diff=0.0;time=0.00214148\n",
      "iter=50;diff=0.0;time=0.00264192\n",
      "iter=51;diff=0.0;time=0.00212836\n",
      "iter=52;diff=0.0;time=0.00211668\n",
      "iter=53;diff=0.0;time=0.00236082\n",
      "iter=54;diff=0.0;time=0.00212312\n",
      "iter=55;diff=0.0;time=0.00229383\n",
      "iter=56;diff=0.0;time=0.00210571\n",
      "iter=57;diff=0.0;time=0.00233650\n",
      "iter=58;diff=0.0;time=0.00232005\n",
      "iter=59;diff=0.0;time=0.00211072\n",
      "iter=60;diff=0.0;time=0.00214601\n",
      "iter=61;diff=0.0;time=0.00212383\n",
      "iter=62;diff=0.0;time=0.00213766\n",
      "iter=63;diff=0.0;time=0.00212216\n",
      "iter=64;diff=0.0;time=0.00214195\n",
      "iter=65;diff=0.0;time=0.00211549\n",
      "iter=66;diff=0.0;time=0.00211596\n",
      "iter=67;diff=0.0;time=0.00212836\n",
      "iter=68;diff=0.0;time=0.00211048\n",
      "iter=69;diff=0.0;time=0.00214243\n",
      "iter=70;diff=0.0;time=0.00212860\n",
      "iter=71;diff=0.0;time=0.00216627\n",
      "iter=72;diff=0.0;time=0.00212073\n",
      "iter=73;diff=0.0;time=0.00213432\n",
      "iter=74;diff=0.0;time=0.00213170\n",
      "iter=75;diff=0.0;time=0.00211358\n",
      "iter=76;diff=0.0;time=0.00213337\n",
      "iter=77;diff=0.0;time=0.00210786\n",
      "iter=78;diff=0.0;time=0.00213552\n",
      "iter=79;diff=0.0;time=0.00215769\n",
      "iter=80;diff=0.0;time=0.00216222\n",
      "iter=81;diff=0.0;time=0.00213027\n",
      "iter=82;diff=0.0;time=0.00213099\n",
      "iter=83;diff=0.0;time=0.00210762\n",
      "iter=84;diff=0.0;time=0.00215054\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 431.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=85;diff=0.0;time=0.00246549\n",
      "iter=86;diff=0.0;time=0.00211954\n",
      "iter=87;diff=0.0;time=0.00226927\n",
      "iter=88;diff=0.0;time=0.00227833\n",
      "iter=89;diff=0.0;time=0.00216532\n",
      "iter=90;diff=0.0;time=0.00214601\n",
      "iter=91;diff=0.0;time=0.00213575\n",
      "iter=92;diff=0.0;time=0.00216484\n",
      "iter=93;diff=0.0;time=0.00246644\n",
      "iter=94;diff=0.0;time=0.00215840\n",
      "iter=95;diff=0.0;time=0.00228596\n",
      "iter=96;diff=0.0;time=0.00217366\n",
      "iter=97;diff=0.0;time=0.00211954\n",
      "iter=98;diff=0.0;time=0.00214362\n",
      "iter=99;diff=0.0;time=0.00231433\n",
      "iter=100;diff=0.0;time=0.00215721\n",
      "iter=101;diff=0.0;time=0.00229454\n",
      "iter=102;diff=0.0;time=0.00212026\n",
      "iter=103;diff=0.0;time=0.00228596\n",
      "iter=104;diff=0.0;time=0.00233483\n",
      "iter=105;diff=0.0;time=0.00212431\n",
      "iter=106;diff=0.0;time=0.00239348\n",
      "iter=107;diff=0.0;time=0.00212955\n",
      "iter=108;diff=0.0;time=0.00214219\n",
      "iter=109;diff=0.0;time=0.00247264\n",
      "iter=110;diff=0.0;time=0.00213099\n",
      "iter=111;diff=0.0;time=0.00240350\n",
      "iter=112;diff=0.0;time=0.00212812\n",
      "iter=113;diff=0.0;time=0.00217056\n",
      "iter=114;diff=0.0;time=0.00213194\n",
      "iter=115;diff=0.0;time=0.00215340\n",
      "iter=116;diff=0.0;time=0.00213027\n",
      "iter=117;diff=0.0;time=0.00214481\n",
      "iter=118;diff=0.0;time=0.00214982\n",
      "iter=119;diff=0.0;time=0.00215268\n"
     ]
    }
   ],
   "source": [
    "# Rebuttal Exp\n",
    "X, y = shap.datasets.adult()\n",
    "# train an XGBoost model (but any other model type would also work)\n",
    "model = xgboost.XGBClassifier()\n",
    "model.fit(X, y)\n",
    "# the last of coff is variational index\n",
    "res, coff = main(model, 0, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "8ae6990f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch:  72%|███████▎  | 87/120 [00:00<00:00, 433.45it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=0;diff=0.00922716052117479;time=0.00230622\n",
      "iter=1;diff=0.0004897810658694828;time=0.00227046\n",
      "iter=2;diff=2.6389841142689566e-05;time=0.00216532\n",
      "iter=3;diff=1.442616699413651e-06;time=0.00231647\n",
      "iter=4;diff=7.869905190325375e-08;time=0.00212169\n",
      "iter=5;diff=4.314238770637735e-09;time=0.00217056\n",
      "iter=6;diff=2.361020385373027e-10;time=0.00211406\n",
      "iter=7;diff=1.2946226023277876e-11;time=0.00215864\n",
      "iter=8;diff=7.09201743436451e-13;time=0.00213480\n",
      "iter=9;diff=3.889088177269123e-14;time=0.00213146\n",
      "iter=10;diff=2.1457481495180527e-15;time=0.00210953\n",
      "iter=11;diff=1.2844765415108726e-16;time=0.00212502\n",
      "iter=12;diff=6.542051911182397e-18;time=0.00217319\n",
      "iter=13;diff=0.0;time=0.00211334\n",
      "iter=14;diff=0.0;time=0.00215626\n",
      "iter=15;diff=0.0;time=0.00212717\n",
      "iter=16;diff=0.0;time=0.00214243\n",
      "iter=17;diff=0.0;time=0.00211716\n",
      "iter=18;diff=0.0;time=0.00213504\n",
      "iter=19;diff=0.0;time=0.00213122\n",
      "iter=20;diff=0.0;time=0.00210881\n",
      "iter=21;diff=0.0;time=0.00213289\n",
      "iter=22;diff=0.0;time=0.00210714\n",
      "iter=23;diff=0.0;time=0.00215816\n",
      "iter=24;diff=0.0;time=0.00211453\n",
      "iter=25;diff=0.0;time=0.00214243\n",
      "iter=26;diff=0.0;time=0.00214243\n",
      "iter=27;diff=0.0;time=0.00239849\n",
      "iter=28;diff=0.0;time=0.00213122\n",
      "iter=29;diff=0.0;time=0.00215244\n",
      "iter=30;diff=0.0;time=0.00212359\n",
      "iter=31;diff=0.0;time=0.00212574\n",
      "iter=32;diff=0.0;time=0.00276494\n",
      "iter=33;diff=0.0;time=0.00214219\n",
      "iter=34;diff=0.0;time=0.00212550\n",
      "iter=35;diff=0.0;time=0.00211930\n",
      "iter=36;diff=0.0;time=0.00210786\n",
      "iter=37;diff=0.0;time=0.00216198\n",
      "iter=38;diff=0.0;time=0.00210905\n",
      "iter=39;diff=0.0;time=0.00213313\n",
      "iter=40;diff=0.0;time=0.00214267\n",
      "iter=41;diff=0.0;time=0.00210738\n",
      "iter=42;diff=0.0;time=0.00213599\n",
      "iter=43;diff=0.0;time=0.00210094\n",
      "iter=44;diff=0.0;time=0.00218439\n",
      "iter=45;diff=0.0;time=0.00217390\n",
      "iter=46;diff=0.0;time=0.00222778\n",
      "iter=47;diff=0.0;time=0.00215220\n",
      "iter=48;diff=0.0;time=0.00212097\n",
      "iter=49;diff=0.0;time=0.00215459\n",
      "iter=50;diff=0.0;time=0.00210428\n",
      "iter=51;diff=0.0;time=0.00218868\n",
      "iter=52;diff=0.0;time=0.00216818\n",
      "iter=53;diff=0.0;time=0.00210667\n",
      "iter=54;diff=0.0;time=0.00211978\n",
      "iter=55;diff=0.0;time=0.00212240\n",
      "iter=56;diff=0.0;time=0.00213242\n",
      "iter=57;diff=0.0;time=0.00213695\n",
      "iter=58;diff=0.0;time=0.00215316\n",
      "iter=59;diff=0.0;time=0.00210595\n",
      "iter=60;diff=0.0;time=0.00212979\n",
      "iter=61;diff=0.0;time=0.00229883\n",
      "iter=62;diff=0.0;time=0.00211287\n",
      "iter=63;diff=0.0;time=0.00213814\n",
      "iter=64;diff=0.0;time=0.00220966\n",
      "iter=65;diff=0.0;time=0.00216937\n",
      "iter=66;diff=0.0;time=0.00210881\n",
      "iter=67;diff=0.0;time=0.00214624\n",
      "iter=68;diff=0.0;time=0.00210595\n",
      "iter=69;diff=0.0;time=0.00214386\n",
      "iter=70;diff=0.0;time=0.00211930\n",
      "iter=71;diff=0.0;time=0.00210047\n",
      "iter=72;diff=0.0;time=0.00212193\n",
      "iter=73;diff=0.0;time=0.00214291\n",
      "iter=74;diff=0.0;time=0.00212789\n",
      "iter=75;diff=0.0;time=0.00210977\n",
      "iter=76;diff=0.0;time=0.00223804\n",
      "iter=77;diff=0.0;time=0.00217366\n",
      "iter=78;diff=0.0;time=0.00217557\n",
      "iter=79;diff=0.0;time=0.00213122\n",
      "iter=80;diff=0.0;time=0.00218701\n",
      "iter=81;diff=0.0;time=0.00213861\n",
      "iter=82;diff=0.0;time=0.00214934\n",
      "iter=83;diff=0.0;time=0.00326824\n",
      "iter=84;diff=0.0;time=0.00228477\n",
      "iter=85;diff=0.0;time=0.00214410\n",
      "iter=86;diff=0.0;time=0.00230074\n",
      "iter=87;diff=0.0;time=0.00217962\n",
      "iter=88;diff=0.0;time=0.00221705\n",
      "iter=89;diff=0.0;time=0.00216770\n",
      "iter=90;diff=0.0;time=0.00220895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 425.90it/s]\n",
      "Epoch:   0%|          | 0/120 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=91;diff=0.0;time=0.00250864\n",
      "iter=92;diff=0.0;time=0.00230908\n",
      "iter=93;diff=0.0;time=0.00229406\n",
      "iter=94;diff=0.0;time=0.00223374\n",
      "iter=95;diff=0.0;time=0.00310683\n",
      "iter=96;diff=0.0;time=0.00215101\n",
      "iter=97;diff=0.0;time=0.00212884\n",
      "iter=98;diff=0.0;time=0.00215077\n",
      "iter=99;diff=0.0;time=0.00231552\n",
      "iter=100;diff=0.0;time=0.00229669\n",
      "iter=101;diff=0.0;time=0.00232792\n",
      "iter=102;diff=0.0;time=0.00213146\n",
      "iter=103;diff=0.0;time=0.00240493\n",
      "iter=104;diff=0.0;time=0.00213337\n",
      "iter=105;diff=0.0;time=0.00237131\n",
      "iter=106;diff=0.0;time=0.00230694\n",
      "iter=107;diff=0.0;time=0.00231194\n",
      "iter=108;diff=0.0;time=0.00215125\n",
      "iter=109;diff=0.0;time=0.00225449\n",
      "iter=110;diff=0.0;time=0.00222349\n",
      "iter=111;diff=0.0;time=0.00239205\n",
      "iter=112;diff=0.0;time=0.00213480\n",
      "iter=113;diff=0.0;time=0.00216222\n",
      "iter=114;diff=0.0;time=0.00249457\n",
      "iter=115;diff=0.0;time=0.00219083\n",
      "iter=116;diff=0.0;time=0.00240731\n",
      "iter=117;diff=0.0;time=0.00230312\n",
      "iter=118;diff=0.0;time=0.00231004\n",
      "iter=119;diff=0.0;time=0.00230408\n",
      "iter=0;diff=0.009227160521174789;time=0.00222921\n",
      "iter=1;diff=0.0004905287863070387;time=0.00212812\n",
      "iter=2;diff=2.6615304466600208e-05;time=0.00214958\n",
      "iter=3;diff=1.4656189227208918e-06;time=0.00213313\n",
      "iter=4;diff=8.053722407902466e-08;time=0.00216269\n",
      "iter=5;diff=4.446983111388276e-09;time=0.00213718\n",
      "iter=6;diff=2.451309334010807e-10;time=0.00215316\n",
      "iter=7;diff=1.353791951324694e-11;time=0.00213099\n",
      "iter=8;diff=7.469571883468947e-13;time=0.00211096\n",
      "iter=9;diff=4.126404804885507e-14;time=0.00214982\n",
      "iter=10;diff=2.2798792793618486e-15;time=0.00216413\n",
      "iter=11;diff=1.136887410828301e-16;time=0.00215435\n",
      "iter=12;diff=1.0343892305196971e-17;time=0.00213456\n",
      "iter=13;diff=0.0;time=0.00215173\n",
      "iter=14;diff=0.0;time=0.00212932\n",
      "iter=15;diff=0.0;time=0.00212932\n",
      "iter=16;diff=0.0;time=0.00213718\n",
      "iter=17;diff=0.0;time=0.00211024\n",
      "iter=18;diff=0.0;time=0.00380325\n",
      "iter=19;diff=0.0;time=0.00213242\n",
      "iter=20;diff=0.0;time=0.00215030\n",
      "iter=21;diff=0.0;time=0.00213766\n",
      "iter=22;diff=0.0;time=0.00210643\n",
      "iter=23;diff=0.0;time=0.00212264\n",
      "iter=24;diff=0.0;time=0.00210857\n",
      "iter=25;diff=0.0;time=0.00214791\n",
      "iter=26;diff=0.0;time=0.00212932\n",
      "iter=27;diff=0.0;time=0.00212407\n",
      "iter=28;diff=0.0;time=0.00213575\n",
      "iter=29;diff=0.0;time=0.00210714\n",
      "iter=30;diff=0.0;time=0.00216222\n",
      "iter=31;diff=0.0;time=0.00211000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 432.04it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=32;diff=0.0;time=0.00252795\n",
      "iter=33;diff=0.0;time=0.00215054\n",
      "iter=34;diff=0.0;time=0.00211644\n",
      "iter=35;diff=0.0;time=0.00213504\n",
      "iter=36;diff=0.0;time=0.00211835\n",
      "iter=37;diff=0.0;time=0.00212717\n",
      "iter=38;diff=0.0;time=0.00211072\n",
      "iter=39;diff=0.0;time=0.00215197\n",
      "iter=40;diff=0.0;time=0.00216079\n",
      "iter=41;diff=0.0;time=0.00213623\n",
      "iter=42;diff=0.0;time=0.00233173\n",
      "iter=43;diff=0.0;time=0.00210786\n",
      "iter=44;diff=0.0;time=0.00213146\n",
      "iter=45;diff=0.0;time=0.00306082\n",
      "iter=46;diff=0.0;time=0.00211000\n",
      "iter=47;diff=0.0;time=0.00213695\n",
      "iter=48;diff=0.0;time=0.00215435\n",
      "iter=49;diff=0.0;time=0.00215364\n",
      "iter=50;diff=0.0;time=0.00212717\n",
      "iter=51;diff=0.0;time=0.00212049\n",
      "iter=52;diff=0.0;time=0.00209999\n",
      "iter=53;diff=0.0;time=0.00215030\n",
      "iter=54;diff=0.0;time=0.00217342\n",
      "iter=55;diff=0.0;time=0.00214410\n",
      "iter=56;diff=0.0;time=0.00212526\n",
      "iter=57;diff=0.0;time=0.00212455\n",
      "iter=58;diff=0.0;time=0.00212264\n",
      "iter=59;diff=0.0;time=0.00212502\n",
      "iter=60;diff=0.0;time=0.00210214\n",
      "iter=61;diff=0.0;time=0.00212908\n",
      "iter=62;diff=0.0;time=0.00230551\n",
      "iter=63;diff=0.0;time=0.00215125\n",
      "iter=64;diff=0.0;time=0.00210094\n",
      "iter=65;diff=0.0;time=0.00212288\n",
      "iter=66;diff=0.0;time=0.00212049\n",
      "iter=67;diff=0.0;time=0.00209975\n",
      "iter=68;diff=0.0;time=0.00211692\n",
      "iter=69;diff=0.0;time=0.00210118\n",
      "iter=70;diff=0.0;time=0.00215292\n",
      "iter=71;diff=0.0;time=0.00472093\n",
      "iter=72;diff=0.0;time=0.00213337\n",
      "iter=73;diff=0.0;time=0.00211000\n",
      "iter=74;diff=0.0;time=0.00215793\n",
      "iter=75;diff=0.0;time=0.00213718\n",
      "iter=76;diff=0.0;time=0.00249076\n",
      "iter=77;diff=0.0;time=0.00210381\n",
      "iter=78;diff=0.0;time=0.00215244\n",
      "iter=79;diff=0.0;time=0.00213385\n",
      "iter=80;diff=0.0;time=0.00211096\n",
      "iter=81;diff=0.0;time=0.00214314\n",
      "iter=82;diff=0.0;time=0.00212598\n",
      "iter=83;diff=0.0;time=0.00214720\n",
      "iter=84;diff=0.0;time=0.00210452\n",
      "iter=85;diff=0.0;time=0.00212049\n",
      "iter=86;diff=0.0;time=0.00209856\n",
      "iter=87;diff=0.0;time=0.00211549\n",
      "iter=88;diff=0.0;time=0.00216842\n",
      "iter=89;diff=0.0;time=0.00213337\n",
      "iter=90;diff=0.0;time=0.00212407\n",
      "iter=91;diff=0.0;time=0.00214219\n",
      "iter=92;diff=0.0;time=0.00215030\n",
      "iter=93;diff=0.0;time=0.00210452\n",
      "iter=94;diff=0.0;time=0.00214314\n",
      "iter=95;diff=0.0;time=0.00212097\n",
      "iter=96;diff=0.0;time=0.00213838\n",
      "iter=97;diff=0.0;time=0.00213742\n",
      "iter=98;diff=0.0;time=0.00210643\n",
      "iter=99;diff=0.0;time=0.00211120\n",
      "iter=100;diff=0.0;time=0.00211453\n",
      "iter=101;diff=0.0;time=0.00209761\n",
      "iter=102;diff=0.0;time=0.00211430\n",
      "iter=103;diff=0.0;time=0.00229239\n",
      "iter=104;diff=0.0;time=0.00212622\n",
      "iter=105;diff=0.0;time=0.00211263\n",
      "iter=106;diff=0.0;time=0.00212288\n",
      "iter=107;diff=0.0;time=0.00210547\n",
      "iter=108;diff=0.0;time=0.00215840\n",
      "iter=109;diff=0.0;time=0.00213051\n",
      "iter=110;diff=0.0;time=0.00210547\n",
      "iter=111;diff=0.0;time=0.00212979\n",
      "iter=112;diff=0.0;time=0.00210810\n",
      "iter=113;diff=0.0;time=0.00214148\n",
      "iter=114;diff=0.0;time=0.00210452\n",
      "iter=115;diff=0.0;time=0.00212336\n",
      "iter=116;diff=0.0;time=0.00210333\n",
      "iter=117;diff=0.0;time=0.00211978\n",
      "iter=118;diff=0.0;time=0.00213361\n",
      "iter=119;diff=0.0;time=0.00216007\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Rebuttal Exp\n",
    "X, y = shap.datasets.adult()\n",
    "model = LogisticRegression(random_state=0, solver=\"liblinear\", C=0.5)\n",
    "model.fit(X, y)\n",
    "# the last of coff is variational index\n",
    "res, coff = main(model, 0, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "517fd474",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch:  71%|███████   | 85/120 [00:00<00:00, 420.76it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter=0;diff=0.004039881102398008;time=0.00230956\n",
      "iter=1;diff=0.00013194248838647473;time=0.00279784\n",
      "iter=2;diff=4.868027286976594e-06;time=0.00217986\n",
      "iter=3;diff=1.863257106563179e-07;time=0.00217557\n",
      "iter=4;diff=7.2436312727768385e-09;time=0.00214577\n",
      "iter=5;diff=2.8413330786059644e-10;time=0.00217843\n",
      "iter=6;diff=1.1186345631504761e-11;time=0.00213647\n",
      "iter=7;diff=4.4179896666286297e-13;time=0.00215816\n",
      "iter=8;diff=1.7462765351577824e-14;time=0.00212860\n",
      "iter=9;diff=6.828379306513001e-16;time=0.00217199\n",
      "iter=10;diff=3.204937810639273e-17;time=0.00215316\n",
      "iter=11;diff=4.625929269271485e-18;time=0.00218868\n",
      "iter=12;diff=0.0;time=0.00215459\n",
      "iter=13;diff=0.0;time=0.00318956\n",
      "iter=14;diff=0.0;time=0.00216484\n",
      "iter=15;diff=0.0;time=0.00215197\n",
      "iter=16;diff=0.0;time=0.00247931\n",
      "iter=17;diff=0.0;time=0.00214815\n",
      "iter=18;diff=0.0;time=0.00213170\n",
      "iter=19;diff=0.0;time=0.00219655\n",
      "iter=20;diff=0.0;time=0.00214767\n",
      "iter=21;diff=0.0;time=0.00255895\n",
      "iter=22;diff=0.0;time=0.00224018\n",
      "iter=23;diff=0.0;time=0.00228119\n",
      "iter=24;diff=0.0;time=0.00216651\n",
      "iter=25;diff=0.0;time=0.00214219\n",
      "iter=26;diff=0.0;time=0.00238156\n",
      "iter=27;diff=0.0;time=0.00215483\n",
      "iter=28;diff=0.0;time=0.00214553\n",
      "iter=29;diff=0.0;time=0.00230479\n",
      "iter=30;diff=0.0;time=0.00229716\n",
      "iter=31;diff=0.0;time=0.00212979\n",
      "iter=32;diff=0.0;time=0.00215030\n",
      "iter=33;diff=0.0;time=0.00241375\n",
      "iter=34;diff=0.0;time=0.00215149\n",
      "iter=35;diff=0.0;time=0.00214028\n",
      "iter=36;diff=0.0;time=0.00215054\n",
      "iter=37;diff=0.0;time=0.00212693\n",
      "iter=38;diff=0.0;time=0.00212836\n",
      "iter=39;diff=0.0;time=0.00214410\n",
      "iter=40;diff=0.0;time=0.00304246\n",
      "iter=41;diff=0.0;time=0.00229549\n",
      "iter=42;diff=0.0;time=0.00217056\n",
      "iter=43;diff=0.0;time=0.00222850\n",
      "iter=44;diff=0.0;time=0.00216460\n",
      "iter=45;diff=0.0;time=0.00255251\n",
      "iter=46;diff=0.0;time=0.00211644\n",
      "iter=47;diff=0.0;time=0.00230908\n",
      "iter=48;diff=0.0;time=0.00213552\n",
      "iter=49;diff=0.0;time=0.00214314\n",
      "iter=50;diff=0.0;time=0.00212741\n",
      "iter=51;diff=0.0;time=0.00216866\n",
      "iter=52;diff=0.0;time=0.00215292\n",
      "iter=53;diff=0.0;time=0.00273848\n",
      "iter=54;diff=0.0;time=0.00214577\n",
      "iter=55;diff=0.0;time=0.00214386\n",
      "iter=56;diff=0.0;time=0.00213695\n",
      "iter=57;diff=0.0;time=0.00229931\n",
      "iter=58;diff=0.0;time=0.00227380\n",
      "iter=59;diff=0.0;time=0.00233674\n",
      "iter=60;diff=0.0;time=0.00212598\n",
      "iter=61;diff=0.0;time=0.00226235\n",
      "iter=62;diff=0.0;time=0.00218511\n",
      "iter=63;diff=0.0;time=0.00211167\n",
      "iter=64;diff=0.0;time=0.00215602\n",
      "iter=65;diff=0.0;time=0.00211477\n",
      "iter=66;diff=0.0;time=0.00216842\n",
      "iter=67;diff=0.0;time=0.00214958\n",
      "iter=68;diff=0.0;time=0.00218177\n",
      "iter=69;diff=0.0;time=0.00214243\n",
      "iter=70;diff=0.0;time=0.00211024\n",
      "iter=71;diff=0.0;time=0.00224280\n",
      "iter=72;diff=0.0;time=0.00211549\n",
      "iter=73;diff=0.0;time=0.00215364\n",
      "iter=74;diff=0.0;time=0.00235510\n",
      "iter=75;diff=0.0;time=0.00211549\n",
      "iter=76;diff=0.0;time=0.00213361\n",
      "iter=77;diff=0.0;time=0.00217485\n",
      "iter=78;diff=0.0;time=0.00216484\n",
      "iter=79;diff=0.0;time=0.00211096\n",
      "iter=80;diff=0.0;time=0.00218391\n",
      "iter=81;diff=0.0;time=0.00218272\n",
      "iter=82;diff=0.0;time=0.00214314\n",
      "iter=83;diff=0.0;time=0.00221014\n",
      "iter=84;diff=0.0;time=0.00211668\n",
      "iter=85;diff=0.0;time=0.00269437\n",
      "iter=86;diff=0.0;time=0.00216460\n",
      "iter=87;diff=0.0;time=0.00215888\n",
      "iter=88;diff=0.0;time=0.00218105\n",
      "iter=89;diff=0.0;time=0.00212884\n",
      "iter=90;diff=0.0;time=0.00213337\n",
      "iter=91;diff=0.0;time=0.00210714\n",
      "iter=92;diff=0.0;time=0.00213361\n",
      "iter=93;diff=0.0;time=0.00215816\n",
      "iter=94;diff=0.0;time=0.00212216\n",
      "iter=95;diff=0.0;time=0.00216484\n",
      "iter=96;diff=0.0;time=0.00210905\n",
      "iter=97;diff=0.0;time=0.00213504\n",
      "iter=98;diff=0.0;time=0.00210714\n",
      "iter=99;diff=0.0;time=0.00213528\n",
      "iter=100;diff=0.0;time=0.00211024\n",
      "iter=101;diff=0.0;time=0.00211120\n",
      "iter=102;diff=0.0;time=0.00216651\n",
      "iter=103;diff=0.0;time=0.00216341\n",
      "iter=104;diff=0.0;time=0.00217152\n",
      "iter=105;diff=0.0;time=0.00228667"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 422.98it/s]\n",
      "Epoch:  37%|███▋      | 44/120 [00:00<00:00, 436.29it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "iter=106;diff=0.0;time=0.00231004\n",
      "iter=107;diff=0.0;time=0.00212479\n",
      "iter=108;diff=0.0;time=0.00210810\n",
      "iter=109;diff=0.0;time=0.00213623\n",
      "iter=110;diff=0.0;time=0.00215054\n",
      "iter=111;diff=0.0;time=0.00216532\n",
      "iter=112;diff=0.0;time=0.00243282\n",
      "iter=113;diff=0.0;time=0.00214672\n",
      "iter=114;diff=0.0;time=0.00212598\n",
      "iter=115;diff=0.0;time=0.00218654\n",
      "iter=116;diff=0.0;time=0.00213933\n",
      "iter=117;diff=0.0;time=0.00216722\n",
      "iter=118;diff=0.0;time=0.00212312\n",
      "iter=119;diff=0.0;time=0.00213599\n",
      "iter=0;diff=0.0040398811023980045;time=0.00290442\n",
      "iter=1;diff=0.00013990319267215352;time=0.00228477\n",
      "iter=2;diff=5.84996325552687e-06;time=0.00214291\n",
      "iter=3;diff=2.529783593082589e-07;time=0.00211883\n",
      "iter=4;diff=1.1072431279083575e-08;time=0.00213957\n",
      "iter=5;diff=4.877132653705576e-10;time=0.00214863\n",
      "iter=6;diff=2.153805539915869e-11;time=0.00213766\n",
      "iter=7;diff=9.532171191940716e-13;time=0.00211573\n",
      "iter=8;diff=4.2218981344183966e-14;time=0.00245094\n",
      "iter=9;diff=1.869791225999455e-15;time=0.00215316\n",
      "iter=10;diff=8.339512588514002e-17;time=0.00213623\n",
      "iter=11;diff=6.542051911182397e-18;time=0.00215650\n",
      "iter=12;diff=0.0;time=0.00211072\n",
      "iter=13;diff=0.0;time=0.00212145\n",
      "iter=14;diff=0.0;time=0.00209904\n",
      "iter=15;diff=0.0;time=0.00211883\n",
      "iter=16;diff=0.0;time=0.00237966\n",
      "iter=17;diff=0.0;time=0.00212216\n",
      "iter=18;diff=0.0;time=0.00214934\n",
      "iter=19;diff=0.0;time=0.00217843\n",
      "iter=20;diff=0.0;time=0.00214624\n",
      "iter=21;diff=0.0;time=0.00210142\n",
      "iter=22;diff=0.0;time=0.00241280\n",
      "iter=23;diff=0.0;time=0.00213528\n",
      "iter=24;diff=0.0;time=0.00211143\n",
      "iter=25;diff=0.0;time=0.00213528\n",
      "iter=26;diff=0.0;time=0.00214672\n",
      "iter=27;diff=0.0;time=0.00213885\n",
      "iter=28;diff=0.0;time=0.00214291\n",
      "iter=29;diff=0.0;time=0.00213981\n",
      "iter=30;diff=0.0;time=0.00232911\n",
      "iter=31;diff=0.0;time=0.00212836\n",
      "iter=32;diff=0.0;time=0.00216985\n",
      "iter=33;diff=0.0;time=0.00212908\n",
      "iter=34;diff=0.0;time=0.00214338\n",
      "iter=35;diff=0.0;time=0.00213814\n",
      "iter=36;diff=0.0;time=0.00210476\n",
      "iter=37;diff=0.0;time=0.00214052\n",
      "iter=38;diff=0.0;time=0.00210357\n",
      "iter=39;diff=0.0;time=0.00212240\n",
      "iter=40;diff=0.0;time=0.00210261\n",
      "iter=41;diff=0.0;time=0.00220370\n",
      "iter=42;diff=0.0;time=0.00210953\n",
      "iter=43;diff=0.0;time=0.00214219\n",
      "iter=44;diff=0.0;time=0.00270009\n",
      "iter=45;diff=0.0;time=0.00211692\n",
      "iter=46;diff=0.0;time=0.00214934\n",
      "iter=47;diff=0.0;time=0.00213027\n",
      "iter=48;diff=0.0;time=0.00214934\n",
      "iter=49;diff=0.0;time=0.00222659\n",
      "iter=50;diff=0.0;time=0.00211644\n",
      "iter=51;diff=0.0;time=0.00212455\n",
      "iter=52;diff=0.0;time=0.00212598"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Epoch: 100%|██████████| 120/120 [00:00<00:00, 430.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "iter=53;diff=0.0;time=0.00218844\n",
      "iter=54;diff=0.0;time=0.00212240\n",
      "iter=55;diff=0.0;time=0.00214958\n",
      "iter=56;diff=0.0;time=0.00213242\n",
      "iter=57;diff=0.0;time=0.00210547\n",
      "iter=58;diff=0.0;time=0.00212884\n",
      "iter=59;diff=0.0;time=0.00214314\n",
      "iter=60;diff=0.0;time=0.00213528\n",
      "iter=61;diff=0.0;time=0.00211716\n",
      "iter=62;diff=0.0;time=0.00214171\n",
      "iter=63;diff=0.0;time=0.00219011\n",
      "iter=64;diff=0.0;time=0.00216103\n",
      "iter=65;diff=0.0;time=0.00214577\n",
      "iter=66;diff=0.0;time=0.00235033\n",
      "iter=67;diff=0.0;time=0.00213504\n",
      "iter=68;diff=0.0;time=0.00209498\n",
      "iter=69;diff=0.0;time=0.00213003\n",
      "iter=70;diff=0.0;time=0.00216055\n",
      "iter=71;diff=0.0;time=0.00215316\n",
      "iter=72;diff=0.0;time=0.00213385\n",
      "iter=73;diff=0.0;time=0.00212693\n",
      "iter=74;diff=0.0;time=0.00212026\n",
      "iter=75;diff=0.0;time=0.00210023\n",
      "iter=76;diff=0.0;time=0.00215435\n",
      "iter=77;diff=0.0;time=0.00211430\n",
      "iter=78;diff=0.0;time=0.00214505\n",
      "iter=79;diff=0.0;time=0.00211453\n",
      "iter=80;diff=0.0;time=0.00211740\n",
      "iter=81;diff=0.0;time=0.00210071\n",
      "iter=82;diff=0.0;time=0.00214577\n",
      "iter=83;diff=0.0;time=0.00212288\n",
      "iter=84;diff=0.0;time=0.00210524\n",
      "iter=85;diff=0.0;time=0.00216413\n",
      "iter=86;diff=0.0;time=0.00213957\n",
      "iter=87;diff=0.0;time=0.00212908\n",
      "iter=88;diff=0.0;time=0.00234175\n",
      "iter=89;diff=0.0;time=0.00260806\n",
      "iter=90;diff=0.0;time=0.00214458\n",
      "iter=91;diff=0.0;time=0.00210333\n",
      "iter=92;diff=0.0;time=0.00217009\n",
      "iter=93;diff=0.0;time=0.00214815\n",
      "iter=94;diff=0.0;time=0.00214243\n",
      "iter=95;diff=0.0;time=0.00213456\n",
      "iter=96;diff=0.0;time=0.00213361\n",
      "iter=97;diff=0.0;time=0.00222373\n",
      "iter=98;diff=0.0;time=0.00213265\n",
      "iter=99;diff=0.0;time=0.00216150\n",
      "iter=100;diff=0.0;time=0.00212789\n",
      "iter=101;diff=0.0;time=0.00209951\n",
      "iter=102;diff=0.0;time=0.00211334\n",
      "iter=103;diff=0.0;time=0.00214577\n",
      "iter=104;diff=0.0;time=0.00218678\n",
      "iter=105;diff=0.0;time=0.00384212\n",
      "iter=106;diff=0.0;time=0.00347805\n",
      "iter=107;diff=0.0;time=0.00211263\n",
      "iter=108;diff=0.0;time=0.00216055\n",
      "iter=109;diff=0.0;time=0.00232887\n",
      "iter=110;diff=0.0;time=0.00211382\n",
      "iter=111;diff=0.0;time=0.00211501\n",
      "iter=112;diff=0.0;time=0.00214887\n",
      "iter=113;diff=0.0;time=0.00211000\n",
      "iter=114;diff=0.0;time=0.00211930\n",
      "iter=115;diff=0.0;time=0.00214911\n",
      "iter=116;diff=0.0;time=0.00209785\n",
      "iter=117;diff=0.0;time=0.00211525\n",
      "iter=118;diff=0.0;time=0.00212216\n",
      "iter=119;diff=0.0;time=0.00209522\n"
     ]
    }
   ],
   "source": [
    "# Rebuttal Exp\n",
    "X, y = shap.datasets.adult()\n",
    "model = MLPClassifier(random_state=0, max_iter=300,learning_rate_init=0.002,hidden_layer_sizes=(50,50))\n",
    "model.fit(X, y)\n",
    "# the last of coff is variational index\n",
    "res, coff = main(model, 0, 0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5e0ff796",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
