{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "34f98c97",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import openml\n",
    "import data_preprocess as dp\n",
    "\n",
    "data_name = 'elevators'\n",
    "\n",
    "data = openml.datasets.get_dataset(846)\n",
    "\n",
    "X, y, categorical_indicator, attribute_names = data.get_data(\n",
    "    target=data.default_target_attribute, dataset_format=\"dataframe\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a854335e",
   "metadata": {},
   "source": [
    "# Data Preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b83124ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "from copy import deepcopy\n",
    "import numpy as np\n",
    "\n",
    "nominal = [b for a, b in zip(categorical_indicator, attribute_names) if a]\n",
    "numerical = [b for a, b in zip(categorical_indicator, attribute_names) if not a]\n",
    "\n",
    "\n",
    "encoded_data = deepcopy(X)\n",
    "\n",
    "for col in nominal:\n",
    "    \n",
    "    mapping = {c: i+1 for i, c in enumerate(encoded_data[col].unique())}\n",
    "    encoded_data[col] = encoded_data[col].replace(mapping)\n",
    "    try:\n",
    "        encoded_data[col] = encoded_data[col].cat.add_categories([0])\n",
    "    except:\n",
    "        continue\n",
    "\n",
    "encoded_data = encoded_data[numerical + nominal]\n",
    "encoded_data.fillna(0, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e5c57b9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mapping = {b: i for i, b in enumerate(y.unique())}\n",
    "\n",
    "y = y.replace(mapping)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "747e1b0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "train_data, left_out, train_label, y_left_out = train_test_split(encoded_data, y, test_size=0.3, \n",
    "                                                                 stratify=y, random_state=42)\n",
    "test_data, dev_data, test_label, dev_label = train_test_split(left_out, y_left_out, test_size=0.5, \n",
    "                                                              stratify=y_left_out, random_state=42)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4c142192",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import Normalizer, StandardScaler\n",
    "\n",
    "ss = StandardScaler()\n",
    "\n",
    "ss.fit(train_data[numerical])\n",
    "\n",
    "train_data[numerical] = ss.transform(train_data[numerical])\n",
    "dev_data[numerical] = ss.transform(dev_data[numerical])\n",
    "test_data[numerical] = ss.transform(test_data[numerical])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3e6f5635",
   "metadata": {},
   "outputs": [],
   "source": [
    "index_to_name, name_to_index = dp.name_index(data=encoded_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d0875dce-a0f8-4f23-b823-c21aaf035772",
   "metadata": {},
   "outputs": [],
   "source": [
    "from imblearn.over_sampling import RandomOverSampler\n",
    "\n",
    "oversample = RandomOverSampler(sampling_strategy='minority')\n",
    "X_over, y_over = oversample.fit_resample(train_data, train_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "56ddde92",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([16056, 18])\n",
      "torch.Size([16056])\n",
      "torch.Size([2490, 18])\n",
      "torch.Size([2490])\n",
      "torch.Size([2490, 18])\n",
      "torch.Size([2490])\n"
     ]
    }
   ],
   "source": [
    "train = dp.transform_to_tensors(X_over, y_over, len(index_to_name))\n",
    "\n",
    "test = dp.transform_to_tensors(test_data, test_label, len(index_to_name))\n",
    "\n",
    "dev = dp.transform_to_tensors(dev_data, dev_label, len(index_to_name))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "61e49abd-ca26-46ff-b249-2cd68a8db382",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader\n",
    "import torch\n",
    "\n",
    "batch_size = 64\n",
    "\n",
    "train_dataset = dp.Data(data=train)\n",
    "val_dataset = dp.Data(data=dev)\n",
    "test_dataset = dp.Data(data=test)\n",
    "\n",
    "train_dataloader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True, drop_last=False)\n",
    "val_dataloader = DataLoader(val_dataset, batch_size=batch_size, shuffle=False, drop_last=False)\n",
    "test_dataloader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False, drop_last=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fe7b1674",
   "metadata": {},
   "source": [
    "# Train KAN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "fb19766d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading saved model\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import os.path\n",
    "from kanshap import train_model, KANSHAP\n",
    "from sklearn.metrics import roc_auc_score, roc_curve, precision_score, recall_score, f1_score\n",
    "torch.manual_seed(5)\n",
    "\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "if os.path.isfile(f'{data_name}/{data_name}_kan.model'):\n",
    "    \n",
    "    print('Loading saved model')\n",
    "    kan_model = KANSHAP(len(index_to_name), 1, index_to_name, dataframe=encoded_data, \n",
    "            categorical=nominal, \n",
    "            numerical=numerical,).to(device)\n",
    "    kan_model.load_state_dict(torch.load(f'{data_name}/{data_name}_kan.model'))\n",
    "    \n",
    "else:\n",
    "    kan_model = train_model(index_to_name=index_to_name,\n",
    "                train_dataloader=train_dataloader,\n",
    "                val_dataloader=val_dataloader,\n",
    "                data_name=data_name,\n",
    "                num_classes=1,\n",
    "                dataframe=encoded_data, \n",
    "                categorical=nominal, \n",
    "                numerical=numerical,\n",
    "                kan_model=None, \n",
    "                optimizer_train=None, \n",
    "                current_epoch=1,\n",
    "                max_num_epochs=300,\n",
    "                learning_rate=1e-03,\n",
    "                num_samples=32,\n",
    "                alpha=1, beta=10,\n",
    "                patience=10)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f5c0b171",
   "metadata": {},
   "source": [
    "## Evaluate the trained model on the test set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a9323f2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████| 39/39 [00:01<00:00, 34.44it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AUC is : 0.9379152823920266,  prec 0.8678277291656338,  recall 0.8585359408033826, f-score 0.8629316929174493\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "\n",
    "list_prediction = []\n",
    "list_pob_pred = []\n",
    "y_test = []\n",
    "\n",
    "for i, data in tqdm(list(enumerate(test_dataloader))):\n",
    "    inputs, labels = data\n",
    "\n",
    "    inputs = inputs.to(device)\n",
    "    labels = labels.to(device)\n",
    "\n",
    "    outputs = kan_model(inputs)\n",
    "    list_pob_pred.extend(outputs.tolist())\n",
    "\n",
    "    preds = (outputs.reshape(-1) > 0.5) * 1\n",
    "\n",
    "    list_prediction.extend(preds.tolist())\n",
    "\n",
    "    y_test.extend(labels.tolist())\n",
    "\n",
    "    torch.cuda.empty_cache()\n",
    "\n",
    "\n",
    "roc = roc_auc_score(y_test, list_pob_pred)\n",
    "prec = precision_score(y_test, list_prediction, average='macro')\n",
    "recall = recall_score(y_test, list_prediction, average='macro')\n",
    "f_score = f1_score(y_test, list_prediction, average='macro')\n",
    "\n",
    "print('AUC is : {},  prec {},  recall {}, f-score {}' .format(roc, prec, recall, f_score))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27113d35",
   "metadata": {},
   "source": [
    "# Explain one random example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "3d76ff08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAuEAAAHnCAYAAAAW8YMSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAADS3ElEQVR4nOzdeVxUZfv48c8MAwwwLLLJHpsCgmiKO25lZlpmpVZqZtbTZlnfMq2nLMvMrdIsl6dVLc1cyiyXTE1zQRABFxTBBWTflZ1hmd8f/OYkgYqlo9b1fr18yczZ7vs+A1znOte5URkMBgNCCCGEEEIIk1Ff7wYIIYQQQgjxbyNBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJqa53g0QQvy7ZGVlmfyYzs7OFBQUmPy4NysZr5aTsWo5GasrI+PVcjf6WHl4eDT7vmTChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMc31boAQQogbS61uJA7XuxE3iVqQsWohGasrI+PVcldzrM6lLrpKe7o8yYQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQoh/jdX1GdjU/IhNzY+8UnfkouudP3+e559/nl69ehEQEECHDh14+umnyczMbLTe8ePHeeSRRwgKCiIgIIDbbruNmJiYy7ZDgnAhhBBCCPGP8WRtHINq9zS7LNNQyf/VHUaD6rL7KSkp4ccff8Td3Z37778fg8HATz/9xOOPP66sc+rUKYYNG8aOHTu49dZbGT58OI6OjmRnZ192//LHeoQQQgghxD+ewWDgP3VxuKMlVGXHWkPmJdd3cHBg586d+Pv7A3DfffcxYsQIjhw5QnFxMa1atWL+/PmUlZXx0ksv8fLLL19ReyQTLoQQQggh/vE+qT9NlKGILzSdsWxBCGxra6sE4AA1NTUA2NnZYWNjA8DevXsBSEhIIDQ0lI4dO/LGG29QWVl52f3/q4PwCRMmMHLkSBITE69bGxYuXMjIkSNZvXo1AKtXr2bkyJEsXLjwurVJCCGEEOJmsqTuNK/UHeGVuiMcNBRzylCuvF5Sd5pEQwlv1R/jDXUwHVT2V7z//Px8Xn/9dQCmTJmChYUFAEVFRQAcPHiQwYMHY2ZmxldffcXMmTMvu08pR/kbRo4cqXxtZmaGvb09nTp14tFHH8XS0vI6tqx5paWlLF26lLi4OGprawkODuaxxx7Dw8PjotusXLmS6Ohopbbp2WefpV+/fsrysrIyli1bxuHDhyktLcXe3p6uXbsyZswYzM3NAdi5cyc///wzOTk52Nractttt/HAAw+gVjdcAy5ZsoQTJ05QUFCAubk5bdq0YfTo0fj4+CjHiYqKYs2aNeTk5NCqVSsGDhzIvffeqyxftGgRiYmJ5OfnA/DWW28RGhqqLM/Ly2P58uUkJSVRWVmJo6Mjffv25YEHHkClUinjs3LlSmJjYykvL8fBwYGhQ4cyaNAgAKZPn05aWhrl5eXodDqCgoIYO3Ysrq6uyljt2bOH8+fPY2Fhgbe3NyNHjiQsLKzF/YiLi2Pt2rWkp6ej1Wrp0aMHY8aMUb7ZFy5cyK5duxqdI0tLS77++mug4Sr9m2++ISYmhvPnz2Nra0t4eDiPPvooOp1OacP69evJysrCzMwMb29vHnzwQaWdlxurQ4cOsWHDBs6ePUtFRQVOTk7cdttt3HvvvcpYCiGEEKa03pDFbkNho/cW1Z8GoLfKiaJ6PXrq2WMoYF9tIUcM5wHYVJ+DFWa8Y9buovtOTU1l1KhRpKWl8corrzBu3DhlmZOTEzk5OTz//PM888wz/PTTTzz99NP8+uuvvPPOO5ds8786E361REZG0rdvXyorK9m2bRvr1q273k1q1oIFC9i9ezceHh6EhYVx6NAhZsyYQW1t7UW3SUlJwcXFBVtb22aXL1u2jF27dqFWq+nXrx9VVVVs3ryZH374AYB9+/axaNEiCgoKiIyMxMrKijVr1rBhwwZlHzt27MDa2ppevXphZWVFfHw87733Hnq9HoDk5GTmz59PQUEBPXv2pK6ujhUrVvDrr78q+0hOTsbb2xuNpvnrykWLFhETE4OtrS2RkZEUFRWxevVqdu7cCTQEr++88w7bt2/H3t6efv364evrS05OjrKPoqIiOnbsSP/+/VGr1cTExDS6Y5GXl0dgYCD9+/fH1dWVpKQkZs2aRVVVVYv6kZyczJw5c0hLS6N79+64uLiwZcsWli1b1qQ//fr1Y/DgwQwePJg777xTef+HH35g8+bNVFVV0bdvX9RqNbt27WLp0qUA5OTkMH/+fM6cOUN4eDgBAQGcOHGiUTsvN1YnTpwgNTWVkJAQbr31VnJzc1m5ciVbtmxpduyFEEKIa22LJpJy83spN7+X0SpvequclNdbNJEYAAOw1ZDHFkMumTT8zkulghhDQza7wFDNyZMnGz1UefToUYYNG0Z6ejrvvfceL774YqPjhoSENNseY7nKpfyjM+EfffQRx44do7S0FI1GQ0BAAI899lijDCvAmTNnWLp0Kbm5ubRv356nn34aW1tbysrK+PTTT0lMTKSqqgoHBwc6dOjAk08+2Wj7oUOH4uvri5OTE2vWrCEtLU1ZVlJSwsqVKzl06BAVFRV4eXkxYsQIOnbs+Jf7ZQyomtOxY8dm952amsqhQ4fQ6XS8/fbbaDQa3nzzTZKSktizZ0+j7PaF3nrrLQBeeeUVSktLmyzPzc0F4N5772XQoEFotVp+/vln8vLyANi/fz8AQ4YMYcSIEaSmpjJ58mR+/PFH7rnnHszMzJg1a5ZSc5WXl8dzzz1HUVERGRkZ+Pv7s379egwGAyNGjOCee+7hyJEjTJ8+nfXr13PHHXcAMH/+fADGjRvX7EWFsZ1jxoyhc+fOVFRUEB0drWTOd+/eTVpaGqGhoUydOlXJ0l9o3rx5ytfR0dF88MEHSj+BRt+YZWVljB8/Hr1ez/nz59FqtZftR3R0NPX19fTp04dnn32W8vJyHnvsMXbs2MGIESNwcHBQ9j98+HAlA99cP/v378/YsWPZsmULX375pdLP/Px8DAYDtra2vPLKK1RVVTF27Fj0ej0lJSVotdrLjlWPHj0YNmxYk+z84cOHueuuu5q0SQghhLjeXjcL5nWzYOX1k7VxrDCk86zan7lm7QH4X/0Z3uvblzvvvJMvv/ySoqIihg8fTmlpKcHBwZw6dYo333wTgMceeww/Pz+eeeYZfvvtNz755BNOnz7Nb7/9BjT8nr6cf3QQXlBQQGhoKNbW1qSnp5OYmMi8efMaBVMAa9asoVu3blRUVHDgwAFUKhWTJk3i559/Zv/+/bRp0wZfX18KCgo4ceJEs8eqqqpSgm9jkF9fX8/s2bNJSUnBz8+Pdu3asW/fPmbOnMk777xDUFDQX+rXpk2bLrrM2tq62SD8zJkzANxyyy1Kttjf35+kpCRSU1P/UjsABg8eTEpKCj/++CNnz54lKioKW1tbpYTDWJKSnp5OdXU1p06dAqC8vJyCggJat27d6KEHYwCtVqtp1aoVgNK+gICARv/n5+dTXl7eoqvNu+++m+XLl/PNN99w4MAB4uLicHFxUS4+jhxpmCe0vr6e5557jvLyckJCQhg/fnyjYHft2rUUFRURFxeHWq1m6NChjY6zZ88eTpw4QXJyMtAQsLZu3bpF/TCOVVZWFhUVFcpY1dXVkZGR0SgInzJlCnV1dUrJS4cOHQC44447iI2N5bfffqOqqor4+HgsLS2VdoaEhNCmTRtSUlKYO3eukv3u06eP0s/LjZW3t3ejPhvPmZOT02XPgxBCCHGzKC8vVxKQSUlJJCUlKcsGDRqEn58fvXr1YsGCBXz00UesW7cODw8Ppk6d2iRh25x/dBD+f//3f0RHR1NUVMQtt9zC8ePHyczMpKioCEdHR2W9Bx98kMGDBytZ2piYGKqqqpTgok2bNkRGRuLl5aVk/y40efJk5etu3boxYsQIAE6fPk1KSgparZa3334brVaLra0tmzZtYsuWLX85CDc+xHklzp9vqH26sFZdq9UCcO7cub/UDoDAwECCgoI4duwY27ZtA6B79+5K4DlkyBCio6PZv3+/khU3OnfunLIeNFzILF68GGgIBI1BuLHtxvZe2Idz5861KAhv3749Pj4+pKWlKZPs33rrrUpge+E3Wa9evcjOziYuLo6ioiLmzJmj7Oe3335TMsKenp74+fk1Os6hQ4eUmm0bGxvCw8OVZZfrx4ABA/j1119JTk5uVG9mXA4NFzXh4eG4urqSnp7OiRMnmD17NrNmzcLHxwcvLy/Cw8OJjo5WzkdoaKgSOGs0Gvr160daWhoHDhwAwN7ens6dO7d4rC60f/9+9u3bh62tLcOGDWt27Ldt26a0ZdasWTg7Oze73rWk0Wiuy3FvVhcvUBNCiBvfp5pOLVrnUxqv97pZMG9VHlZeOzs7U11dfdl9PfXUUzz11FNX3M5/bBCenZ3NlClTlEzfhUpKShoF4Z6eno3+h4b63yFDhpCWlsYvv/zCpk2bUKvV9OzZk+eee65RuUJkZCTnz5/nyJEjHD16lMLCQtzd3ZVSBScnJyXwMh6joKDgL/ftr5Sj2Ns3PAl84YfJODbNBVct9eGHH3Ly5ElGjRrF4MGDWb58OVu3bgXgpZdewt/fn/nz57N//37KysoIDg7m/fffR6/XY2dnp+ynpKSEmTNncurUKW6//XZGjx7dqO0FBQVKey88py1pe319PTNmzKC4uJiJEycSERHBggUL2Lp1K1qtljFjxiht6dixIxMnTqSkpIQnnniC1NRUCgoKlABu4cKFVFVV8fvvv/P5558ze/ZsFi9erJzfCRMm8NRTT5GSksKsWbP43//+h6enJ8HBwZfth42NDfPnz2fv3r0UFxcTEBDA119/TW5urtK+//znP40efnzjjTdITk7m4MGD+Pj48NlnnxEdHc3AgQMZO3YsmzZtYuXKlcybN4+ZM2cSHx/PZ599hrOzM++++y5VVVW8+uqrzJ8/Hy8vLzw9PS87VkY7duzg008/RafTMXXq1IsGuQMGDGDAgAHK67/z2f+rnJ2dr8txb1YO17sBQghxnVyL3xUXmwDjH/tgZlxcHFVVVfj6+rJ06VI+++yzi65rzPZd+GdIHR0d0el0vP766yxfvpy5c+fi7e2tlBtcaOjQobzxxhuEhYVRXl7OihUrAJTb+4WFhUrwm5WVBfC3snKbNm266D9jGcSf+fr6Ag0lEcZ5Lo3lDrfccgvQEAgb7xS0VHp6OtCQEbewsFBKLIxjWVdXh5OTE3fffTcPPfQQxcXF6PV6XFxccHNzAxrKMaZOnar81amnnnqqUaBpbPvJkycbtdvZ2blFWfCysjKKi4sBaNu2LVqtVtlnRkYGQJPnBC6k1WqpqqrCYDAor7t06QI03KoqKSmhtrZWGVeNRkNwcLByoWd8wONy/TAYDFhbWzNo0CAefvhhrK2tyc3NxdLSkjZt2gB/1Hz/mXG8jP0JCAjAwsKCwMBA4I/zYTxfLi4uODo64uHhga2tLQaDgczMzBaNFTQ8ALpkyRKcnJyYPn26so4QQgghWuYfmwk3Zn6zs7P56quvLln3/N1335GamqrMF961a1e0Wi1r1qwhNjYWHx8fNBqNktm2trZusg+VSsXIkSM5evQoBw4cIDMzE39/f6X+9s0338Tb25u9e/eiUqkazWhxpf5KOYqfnx/h4eEcPnyYadOmYWtry4kTJ3ByciIyMhKALVu2sHbtWiIiIpQSm/Xr15OZmalcGW7fvp3ExERuv/12goODCQ4O5tChQ/zvf/+jffv2SolDcHDDww+ZmZm8//77hISEUF5ertTcjx49Wgkc33jjDYqLi3F2dkav1yuZ/sjISAIDAxk6dCgHDx5kzZo1nD17VqnfvrD8Yfny5ZSWlioXO+vXr2fnzp0MGzYMT09P3N3dyc7OZu7cuQQEBBAVFdWonQMGDODHH38kISGBBQsWKIFzp06d0Ol07Ny5k3Xr1tGmTRssLS05fLjhdpWHhwcuLi7k5+czZcoUwsLCsLe358yZM2RmZmJhYaE8OX25flRXV/Piiy8SFhZGXV0dMTExAIwYMQIrKysAXnjhBdq1a4e7uzvp6ekkJydjaWlJ165dAQgKCiI9PZ2VK1eSkpKiHMPYz6CgIFQqFcePH+fDDz+kurqa/Px8zM3NCQgIwM7O7rJjtW3bNr799lug4eLLeOdDp9O16EEUIYQQQvyDg/CePXty9OhRoqKiOHLkCGPHjlVm0PizESNGsGvXLkpKSoiIiFCK6f38/IiPj+fAgQPU1NTg7OzMQw89pGSO/yw4OJjQ0FASExP58ccfefbZZ5k8eTIrVqzgyJEjxMTE4Ovry/Dhw5WAxpQmTpzYaJ7w8PBwHnvsMeWBwOYkJCRw7Ngx5fWJEyc4ceIEoaGhBAcH8+yzzyr927lzJ/b29gwaNIhRo0YBDYGZjY0N+/bto76+noCAAO6//34iIiKUfRozrwUFBY0eOvX19SUwMJDg4GBeeOEF1qxZw969e3FwcGDUqFHKzChAo9k7oKE2Gxqm8vP09GTKlCmsWLGC5ORkdu/ejaOjI3fddZfywOKFdz2io6PR6XQMGDBAKYtxd3fHzs6O+Ph49Ho99vb29O/fnxEjRqBSqbC2tiYwMJCkpCTKysrQ6XTceuut3HfffUrG/3L9MDMzo3Xr1sTGxqLX63F3d2fIkCHcdtttSr/uuusuEhISOHnyJBYWFrRv356RI0cqt7oeeeQRzMzMOHjwIDt37sTW1pY+ffooZSRBQUFMmDCBn3/+mYSEBFQqFW3btmX48OG4uLgAXHasLrxTYgzQoSG7LkG4EEII0TIqg/EeuxBCmICxJMuUpCb8yjj4Pnu9myCEENfFudRFV32f/7qacCGEEEIIIW5UEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFimuvdACGEEDcWTdlqCgoKrnczbgrOzs4yVi0kY3VlZLxa7mYdK8mECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIyT7gQ4qbWY41HC9ds6Xoi5Rn99W6CEEL840kmXAghhBBCCBOTIFwIIYQQQggTkyBcCCGEEEIIE5MgXAghhBBCCBOTIFwIIYQQQggTkyBcCCGEEEIIE5MpCoUQ/zjnfnqNisPfU5ufDIDjw1+h6zbub21TumsBpbsXUHc+E9TmmLu2xfa2ydjcOvJadUMIIcQ/mGTChRD/ONVno9E43oLaxumqbVNbdAZztzBsuj6Ghdet6NMPUrj8YWryT16tZgshhPgXkUy4EOIfp/WEHQBkz+lIfXnhVdmm1X3zlK8NBgMZr7XCUHWeuuKzmLsEXoVWCyGE+DeRIFwIIVqo8vgWKo9tpCbrMIaq81j6R2LpH3m9myWEEOImdFOWo0yYMIGRI0eSmJgIwLRp0xg5ciQ7d+78S/vLy8tj5MiRjBwptZ1C3Gyq02Io/v5F5d+1LA+pTt1P2e5PqD71OypzLdqQwWBmfs2OJ4QQ4p/rH5EJ7969O76+vnh5eV2zY+zcuZNFixYpry0tLXFzc+Oee+6hT58+Ld6PMdD/5JNPcHV1vertvJzS0lKWLl1KXFwctbW1BAcH89hjj+Hh4fGXt7nYxUvfvn2ZMGECAL/88gtbtmwhPz8fCwsLAgICGD16NL6+vgCkpqayYsUKTp06hV6vx8XFhUGDBnHnnXcqy5cvX87JkyepqqrCxcWFhQsXNjpec+248847efzxx4GGMT9y5AilpaVYWVnh7+/PqFGj8PPza7RNTk4Or7zyCtXV1dxyyy3MnTsXgGPHjvHVV1+Rl5dHbW0tTk5O9O7dm+HDh6NSqQCIiopi/fr1ZGVlYWZmhre3Nw8++CBhYWEA1NfXs3btWnbs2EFJSQmenp48/PDDdOrUCYDExETefvvtJv146aWX6N69O3l5eXz99decPn2ac+fOodPp6NSpE6NHj0an0wENF5XLly8nKSmJyspKHB0d6du3Lw888IDSztLSUlauXElsbCzl5eU4ODgwdOhQBg0apBxz27ZtbN68mezsbCwtLQkICOCNN95o8Tk3lZqcY5T+/pHy2qr9sGtWHuJw1zTsB75BTe4x8j+7h/Mb/4umlQ82EaOvyfGEEEL8c/0jgvALA4drzdbWlt69e5OdnU18fDwLFy7E39//ml4AXE0LFizg0KFDtGnTBjs7Ow4ePMiMGTP46KOP0Gia/zhcbpvBgwc3Wn/nzp1UVFTg5uYGNASWX3zxBSqVil69epGdnc2hQ4fIzMxULmzmzp1Lfn4+AQEBeHh4sGfPHr744gs8PT0JCwujoKCAc+fO4efnx/Hjxy/aP0dHR7p37668Dg4OVr4uKCigXbt2WFtbc/To0SZtAKirq+Pjjz+mtra2yb6LiorQ6XS0adOGsrIyYmJiWLNmDc7OzvTv35+cnBzmz5+PwWCgS5cuVFVVceTIEWbNmsXnn3+OVqtlw4YNrF27FhcXF3r27ElUVBRz5sxh7ty5eHt7K8dq06YNbdq0UV4bxzI/P5+4uDhCQ0MJDQ1l//79bN++ndLSUiZNmgTAokWLOHbsGJ6ennTu3Jk9e/awevVqnJyc6N+/PzU1NbzzzjukpaXh4+NDly5dOHfuHDk5Ocrx1q9fz8qVK7GysqJnz56o1WqSk5OV5Zc756ak6zbusjOf/FldWQH15QWoLG3ROHi2aJv6qlLUWltUZhosPMIxdw2mrvgsNfnJl99YCCGE+JMbNggvLCzk22+/5dixY5w/fx5XV1cmTJhAYGDTDNe0adM4duwYzz77LP369WPhwoXs2rWLPn36UFJSQmJiIiEhITz11FMsW7aMQ4cO4ePjwwsvvNAkG/3777+zcuVKampq6N+/P6NGjUKt/qNqx9HRkXHjxgENZTH5+fmcPXsWLy8viouLmT9/PhkZGVRUVGBtbU2HDh14/PHHsbGxaZQ9fO655wB46623CA0NZceOHWzevJmcnBxatWpFv379uPfeezEzM2t2fJYuXXrRsevYsSMdO3Zs8n5qaiqHDh1Cp9Px9ttvo9FoePPNN0lKSmLPnj3069fvL21jHA+As2fPsmnTJszNzbnjjjsAyM3NBcDPz4+JEydy9uxZJk2aRFFRkRLsFhQUAPDMM8/g4+NDZmYmp0+fJj8/H4CIiAgiIiKIiYm5ZBDu5ubWqD0XmjZtmvL16dOnefXVVyksLKS2tla5APn+++9JS0vj7rvv5scff2y0fWRkJJGRf9T/zp49m4MHD5KXlwc0BMgGgwFbW1teeeUVqqqqGDt2LHq9npKSEszNzfnpp58AePnll/H398fZ2Znvv/+eDRs2NMogd+jQodlss7u7O5988gmtWrUCoF27dixatIgjR44o6xjHe8yYMXTu3JmKigqio6OVsdy9ezdpaWmEhoYyderURp9vgIqKCtatW4dGo2HmzJnN3iW53Dm/3s5vm0VtbhJ1584CUL7/c6pP7sSmxxNo/SMp3f0JJb+8jVXYvbg8sb5F22S+6Y62zW2Y2XtSU5BCdfJ2UKnRBt0YfRZCCHFzuSGD8Orqat555x2ys7Nxd3end+/eZGRkUFxcfEX72b17N926dUOn03H48GFeeeUV/P39cXV1JSUlhVWrVjFx4sRG26xZs4bw8HCioqLYsGEDTk5O3HXXXU32nZ2dTVlZGSqVCh8fHwAqKyvR6/V07twZCwsLjhw5wp49e9BqtTz55JMMHjyYTZs2AdCvXz+sra1xcnLi119/5bPPPsPJyYkePXpw+vRpVq1aRV1dHSNGjGi2b8b9NMfa2rrZIPzMmTMA3HLLLUrQ6e/vT1JSEqmpqc3u60q32bhxI9AQsNrZ2QENAbS7uztnzpzh448/JisrC5VKxbBhw5R9Dh48mI0bN7J48WI8PDw4c+YMt9xyC127dr1oP5uTkpLCmDFjsLa2pn379owZM0YJWAG2bNlCRkaGErTec889ShtOnjzJ999/z7hx47C0tGx2/zk5OWzZsoWioiLi4+OVUg+AkJAQ2rRpQ0pKCnPnzqWqqgqAPn364OrqSl5eHqWlpahUKqUEJiAgAKDJWG7cuJH169fj6OhI7969eeCBB9BoNDg6OjZaz3gRc+H7d999N8uXL+ebb77hwIEDxMXF4eLiolxkGfteX1/Pc889R3l5OSEhIYwfP1753qiurqZVq1YsWbKEM2fO4OLiwsiRIxvdZbiwrdD4nF9vVce3UH1ql/K6+sxeqs/sxTKwH1zkQcrLbaNtOwB9+gHqkn5BrbXDMqAvdrdNQisPZgohhPgLbsggPD4+nuzsbFq1asWcOXOUgKi5EoFLCQsL46WXXmL16tWsXbsWCwsL3njjDeLi4pgzZ06zQeTLL7+Mr68vvr6+LF26lN9//71REJ6WlqZkKM3NzZkwYYJSiuLh4cGTTz7J4cOHOX/+PF5eXmRnZysPkI4bN04JnocPH65k4efMmQNAYGAg1tbW+Pj4cPbsWbZu3XrRIHz16tVXNBYA58+fB2gUYGq1WgDOnTv3t7cpKSlhz549AAwZMkR5X6fTERkZybp169i9ezcArVu3VuqkAbp06UJMTAynTp3i1KlTmJmZ0aVLF6ysrFrcv1atWhESEoJWqyUuLo7du3eTm5vLu+++q6yzf/9+jh07BoCTkxNBQUFAw4Xfxx9/THh4OHfeeedFH/ItLCxsdAEUGhqqBJ4ajYZ+/fqRlpbGgQMHALC3t6dz586NxsvS0lKpzTaOq3GZSqXC29ubgIAAampqiImJYd26ddTV1TFq1KhGbcnKyuLbb79FpVIxZswY5f327dvj4+NDWloamZmZANx66604ODgADfXgAElJSUp5UFxcHEVFRcyZM0dZXlxcjKOjI126dGHv3r3Mnz+f9957D39/f+VYFzvnF9q2bRvbtm0DYNasWTg7Oze73tXU+vmdl1zucNc0HO6adkXbGDPm/wYajcYk5+mfQMaq5WSsroyMV8vdrGN1Qwbhxtv7Pj4+jYK/i9UsX4ynZ0Otp42NDdBQqqBWq5XArrq6usk2FwbU0BB0XcjW1paePXsSGxtLYWEh+/btUx7M3LNnDwsWLGiyz5KSkku201gmEB0d3ej98+fPU1VVpQS9F/or5Sj29vZA434bs7XGAO3vbLN161ZqamoICwtT7g5AQxC2Zs0aAgICeP3118nIyODNN99k9uzZLFy4EJVKxcyZM5U7IF5eXsyYMYO1a9dib2+vPJx5OUuWLFGC26ysLF588UWSk5MpLi5WsuHTpk1Dr9dz6NAh3n//fT788EMWLFhAfn4+2dnZ6HQ6Zs2apZz3vLw8Zs2axauvvgo0BN3fffcdRUVFfPrpp+zevRtzc3Oefvpp4uPj+eyzz3B2dubdd9+lqqqKV199lfnz5+Pl5aWMV3V1NfX19ajV6iZjGRISwgcffKD0yXiXJDo6ulEQfvLkSWbOnEl5eTnPPPOMEujX19czY8YMiouLmThxIhERESxYsICtW7ei1WoZM2aMctHQsWNHJk6cSElJCU888QSpqakUFBQ0yma/9tpr2NnZUV5eTnx8PHFxcY2C8Iud8wsNGDCAAQMGKK+NpUdXz8UfKhZ/TW1t7TU4T/9Mzs7OMlYtJGN1ZWS8Wu5GH6uLTX5xQwbhxgzx2bNn0ev1WFhYAA0PzV2sRro5f651/fPr5mRkZODr60tWVhbQkC29kKOjI48//jiDBw/m5ZdfJi4ujtjYWCIiIti3bx/QEHSMHz+emJgY5UE9I5VKhcFgaPSei4sLGRkZTJ48mYiICOX9vLy8ZgNw+GvlKBfORFJTU4O5uTmnTp0CGspNoOGCwTh7iKOjY4u2gYZf2r/++ivQNCOanp4ONFwU6XQ6AgICMDMzo7q6moKCAgwGA9XV1ZiZmREQEIC5uTmenp6cOnVKyeReTlFRETY2Ns2WkahUKvR6PRqNBrVajYWFBR07dkSr1VJZWUlubq4SvKekpDTatrKykri4OOVrKysrVCoVTk5OBAcHK3dtLuyni4uLUh5ia2tLVVUVmZmZdOnSBZ1OR1lZGadPnyYwMLDJWObm5tK6dWulPUYXfnYPHz7M+++/T11dHS+//DJdunRRlpWVlSllW23btkWr1eLr60tsbCwZGRkAFw2WoeEuh5eXF2q1mvr6+maXG13qnAshhBDi0m7IIPzWW2/F3d2d7OxsJk+eTLt27cjMzOTuu+9uFHBcCx988AEhISFERUUB0Lt372bXc3d3p0+fPuzYsYP169cTERGhZDONGdH4+Pgm2zk7O5Ofn8+XX36Ju7s7Dz30EIMGDeLzzz/n448/pmvXrhgMBk6dOoW9vX2jhwkv9FfKUfz8/AgPD+fw4cNMmzYNW1tbTpw4gZOTk/LA4ZYtW1i7di0RERFMnjy5RdsA7Nu3j+LiYtzd3ZXp9oyCgoL45Zdf2Lt3L9AQaNbV1WFra4unpycGg0EJTt955x1at26trGuc3SQzM5P169crV7olJSUsXLgQW1tbxo4dy+HDh1m+fDlhYWFYW1srgXP79u1xcHAgMTGRBQsWEBISgo2NjTJ9n52dHf7+/lhbWzcaU+OUlBdOUTh37lzq6urw9PSkrKyMgwcPAg0PURr7qVKpOH78OB9++CHV1dXk5+djbm6uXHjcfffdrFq1innz5imfM7VazdChQwFYt24dJ06coG3bttTV1RETEwOgjHV6ejqzZs2itraWoKAgEhMTlXKn4cOHY2dnp3zvzJ07l4CAAOWzbBzLAQMG8OOPP5KQkMCCBQuUi4hOnTop0xxGRkby+++/M3PmTNzd3UlISECr1Taq0b/UORdCCCHEpd2QQbilpSVTp05l1apVJCYmsmvXLlxdXRs9YHetjBgxgpUrV2JhYcEdd9xxyekP77vvPnbt2kVycjLHjh1j+PDhZGdnk5yczOnTp7nvvvv46quvGm0zevRovv76axISEoiPj+f+++/njjvuQKPRsGXLFvbv34+FhQVeXl7cdtttV71/EydObDTnd3h4OI899hjm5hf/gyMt2caYmb/rrruaZHEjIyM5d+4c27dvV/rXvn17Hn74YSVz/dprr7Fq1SrOnDnDmTNncHNz44477qBnz55AQ830rl0XPDRXXc2uXbtwcXFh7Nix+Pv7ExISwokTJygtLaVVq1YMGjRIqd9v1aoV7u7uHD58WAm+u3fvzvDhw7G2tm7R2LVr147ff/+dkydPotFo8PDwoG/fvkoWOCgoiAkTJvDzzz+TkJCASqWibdu2DB8+HBcXFwCGDRuGXq/nt99+Y+/evXh5efHQQw8p2ekuXbqQl5dHXFwcer0eV1dXbr/9dmVKwJKSEuXZiBMnTnDixAmlfYMHD0an0zFlyhRWrFhBcnIyu3fvxtHRkbvuuksJ9HU6Ha+//jrLly8nOjoanU7HgAEDGD36j7mun3jiCSwsLIiOjiYrK4vg4GBGjx7daDahS51zIYQQQlyaynBhXYQQQlxjxlKvq6XHGqkJv9pSntHf0PWVN5IbvRb1RiJjdWVkvFruRh+ri9WE35R/tl4IIYQQQoibmQThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmOZ6N0AIIf6OqBFZl13nRv+Txjce5+vdACGE+MeTTLgQQgghhBAmJkG4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJvOECyGEaKRWNxKH692IG9y51EXXuwlCiJucZMKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCiAtUGep4ue4wt9RsxqnmJ26v3c2B+qJLbpOcnMyjjz5KWFgYbdu2Zfz48WRkZCjLu3XrhqenZ5N/w4cPv9bdEULcoOSP9QghhPhXerI2jrNUsEUT2ej9yfVH+aI+lXbY0k/lwjpDJvfURXFUNQBnlWWT/Zw/f56HH36YnJwcBgwYgIWFBZs2bSI1NZVt27ahVqt56KGHKC4uVrbZvHkzWVlZ+Pr6XutuCiFuUBKECyGEEP9fnqGa5fVpqIGNml64qizR1KpYZcjgf/VneN0suMk2Bw4cICcnB29vb5YtWwbAHXfcwbFjx9i8eTNDhgzh//7v/5T1CwsLWbFiBQDjx483Sb+EEDceKUcRQggh/r/jhhJqMOCNNa7/P+vdSeUAwGHD+Wa3sbRsWK+4uJi0tDSysrLIzc0F4NixY03WX758OVVVVfTq1Yt27dpdg14IIW4GV5wJX7hwIbt27WLw4MGMGzeOnTt3smjRItq1a8e0adMASExM5PPPPyc7O5v6+nqWL19OWVkZCxcuJDk5mZqaGqZMmULnzp3/dgcSExN5++23cXFxYeHCheTl5fHcc88BsHr16r+9fyGEEP8cS+pOc4pyAA4aiimhllfqjgAQgA1OKgsAbDBTtrFRNfyqzKW62X326NGDLl26cODAAXr27NloWX5+fqPXer2er7/+GoAnnnjiKvRICHGz+tvlKF5eXgwePBg3Nzflvc8//5zMzEw6duyIh4cHGo2G9evXk5iYiLe3N+3bt6d169ZKQG+k0+m45ZZbGD16NIGBgX+3aYoJEyYoPwhVKhX29vaEhYUxduxYHBwcWrSP1atXs3btWvr27cuECROuWtuuRFRUFGvWrCEnJ4dWrVoxcOBA7r333r+1TV5eHkuXLuXIkSOo1Wo6dOjA+PHjlXH59ttviYuLIy8vDwBfX18efvhhgoMbbslOmzat2UyP8aLIeJHWnLfeeovQ0FAAzp49y4oVK0hKSqKuro7WrVvzn//8h+DgYDIyMli0aBFZWVno9XocHBzo0qULo0ePxsLCokXHKCsrY9WqVRw8eJCSkhJ8fHx45JFHGmWhfvnlF7Zs2UJ+fj4WFhYEBAQwevToRjWbMTEx/PDDD5w9exaNRoOPjw9TpkxBp9NRU1PDN998Q0xMDOfPn8fW1pbw8HAeffRRdDodAPX19fz444/s2LGDgoICrK2t6dy5M88++yzQcJv6m2++4ejRo1RWVtKmTRvGjRvHLbfcorShtLSUlStXEhsbS3l5OQ4ODgwdOpRBgwYBcPToUb777jvS09Opq6vDw8ODYcOG0aNHDwA2bdrE7t27ycnJoba2Vnk4LCIiAuCy4w2Nv6eMOnXqxKuvvtrseRDiRrHekMVuQ2Gj9xbVnwagt8qJ11RBAJRTpywvM9QC0Jqm9eAAGo2GNWvW8NNPP5GcnIynpyfR0dH88MMPODo6Nlp3w4YN5Obm4uvryx133HHV+iWEuPn87SA8MDCwScCcnZ0NwOOPP07r1q0bvTdkyBBuu+22Ruv7+voSHBxMUlISiYmJzJ07l//9739/t2lNdOrUCWdnZ2JiYtizZw/19fW8+OKLV/0410JycjLz58/H0tKSnj17cvToUVasWIG1tfVFf5Bfbpv6+npmzZpFRkYGHTp0oKamhv3791NYWMiMGTMA2LNnD9bW1nTv3p2TJ09y/PhxZs6cybx583B0dKR79+6NgtQjR46Qnp6uXJQZL9KMioqK2L9/PyqVCldXVwCysrKYOnUqlZWVygVadnY2hYUNvyjLysowMzOje/fu1NTUEB0dzebNm7GxsWHkyJEtOsbHH39MfHw8fn5+hIeHs3fvXmbMmMH8+fNxcXEhMTGRL774ApVKRa9evcjOzubQoUNkZmYqAf6ePXtYsGAB5ubmdOnSBa1Wy8mTJ9Hr9QD88MMPSrv69u1LQkICu3btwmAwKHdnPv/8c7Zt24aDgwO9e/emtrZWucCpr69n5syZnD17lpCQEJydndm7dy/Tp0/n448/xsrKipqaGt555x3S0tLw8fGhS5cunDt3jpycHACqqqqYPXs21dXVhIWFYW1tTUxMDPPnz8fPzw83NzdiYmKoqKggIiKCrKwsUlJS+OCDD3jvvffw8/O77HgbWVlZ0b9/f+W1l5fXFX2mhbgeLnwIs7kHM3MNVZijIp0Kcg1VtFZpOWg4B0B7lT0A5w01nDx5EktLS5ydnQEwGAzcf//9QMPF9Jw5cwDo3bt3o+N/8cUXQEMWXKVSXZtOCiFuCpcNwpOSkvjss8/Iy8ujW7du1NbWNlr+53KUC39JP//887i4uODi4qJkS5csWcKSJUv45JNPlPXatWvHuHHjyM/PZ8KECRQXF3P+/Hns7e0xGAxs376dzZs3k5eXh4ODA7169eL+++9XsnItddttt9G1a1cCAwNZtGgRaWlpyrINGzawbds2iouLqaurw9PTkwceeIDu3bsrWXCAXbt2sWvXLqW/BQUFfPPNNxw/fpzq6moCAwMZO3YsPj4+zbYhISGBhISEi7Zx3Lhxzb6/fv16DAYDI0aM4J577uHIkSNMnz6d9evXXzQIv9w2sbGxZGRk4OPjw+uvv059fT3PP/88KSkpJCYmEhoayssvv4y/vz/QEOD95z//obKykpSUFLp166ZkXwFqa2uVuwR33XUX0PQibfny5QB06dIFFxcXANatW0dlZSXDhw9v9PkxCg4OZvr06cprGxsbtmzZogSvlztGZWWlMuaTJk3CxcUFKysrNm3axE8//cT48eOV+k0/Pz8mTpzI2bNnmTRpEkVFRdTW1mJmZqY8SPXf//5XyeBfyLiP/v37M3bsWLZs2cKXX36pZIyzs7PZvn07tra2vP/++9jZ2TXaPjMzU8mwT506FY1GQ2VlJbGxsWzbto177rmH3bt3k5aWRmhoKFOnTkWtbvxYx7lz56iubrhlPnnyZLRaLY8//jilpaUUFBTg5ubG2LFjlXNaX1/PCy+8QG5uLomJifj5+V12vI10Ot1FP69C3Kxaq7SMUfnwlSGNIbX7CFXZsc6QiQ4znlL7AbDBkM3TffvSrl074uPjARg1ahStWrXCzs6O3377jaKiIm6//XZ69eql7Ds6OprDhw9jb2/f7M86IcS/yyWD8PLycmbPnk15eTlhYWGUlpZeMoAEGDx4MJs2bQKgX79+uLq6otPpyMnJoaioiPDwcLy8vLC2tm60XX19PSkpKQC0atUKW1tbALZu3coXX3yBtbU1PXr0IDExke+//56SkhKefPLJK+5wbW0tp0833Hq88BZ/Xl4ePj4+hIeHU1JSQkxMDB9//DH+/v60bduWNm3akJKSgqenJx06dMDNzY3q6mrefvtt8vLy6NChA3Z2duzdu5d33nmHDz/8sEmQBQ3ZaeP4NOdiQU1qaioAAQEBjf7Pz8+nvLwcGxubK97GuNwYkKnVanx9fcnPzyc1NZXQ0FBlGTRkeurqGm7ROjk5NTnevn37KC4uxs3NjU6dOjVZXlVVxY4dO4CGOyJGR48eBeDUqVOMHz8eMzMzevTowejRo5UHnsrKyli7di2lpaVER0djY2PDwIEDW3QMjUaDWq2mrq6O06dPY2trS3p6OoByIRYREYG7uztnzpzh448/JisrC5VKxbBhw9BoNGRlZVFYWIiFhQUbNmxg1qxZODg4MGTIEOVCxHhh89tvv1FVVUV8fDyWlpYMHToUaHh+wWAwYGdnx7vvvkt2djaenp488sgjhIaGYm5uDkBdXR2pqam4ubkpgb2xnUeONNSu1tfX89xzz1FeXk5ISAjjx4/H1dUVNzc3unbtSkxMDHPmzMHa2prS0lLat29PSEhIo/NtZLywvvC2eUvGu6ioiLFjx2Jubk5QUBBjxozBw8OjyTkR4mYz16w95vUqvq/P4idDNl1VrZipDsOlmekJjUJCQtiwYQPnzp3D1dWVCRMm8NJLLzVa5/PPPwfgoYceavZnthDi3+WSQfjBgwcpLy/Hzc2NqVOnolKpmDJlCmfOnLnoNuPGjVOCzOHDhyvlAPv376eoqIjIyEj69evXaJtNmzYp2zg5OfHKK68oGb4tW7Yo++3Xrx+pqalMnjyZ7du3X3EW7v3331e+NgYuRmPGjCE6Oprs7Gw0Gg12dnacO3eO5ORkIiMjSU5OJiUlhcDAQOW4UVFR5Obm4ujoqAQfzs7O5Obmsn///maDxJEjR/6lDMj58w1P5Wu1WuCPp/GhIfvZ3A/0y21z7ty5RssvXMe4zKiuro6FCxdSW1tLjx49mq3ZN57Du+66q0mGFuC3336joqICPz8/JSAEKCkpARouULp160ZCQgJbtmxBrVYrY11RUdHo4qVdu3bKbeDLHcPc3JwhQ4awYcMGPvjgg0brG/up0+mIjIxk3bp17N69G4DWrVsTFhYGNNRhQ8NDVbm5ufTo0YO9e/fy5Zdf4ujoSNeuXfHy8iI8PJzo6Gi2bdsGQGhoKN7e3o36mZmZSWhoKO3btyc2NpbZs2czb9483Nzc6NmzJ/v27eO///1vs+00tiMpKUkpm4mLi6OoqEi5/d2nTx+OHz+uXNxotVq6du2KmZkZf7Zs2TIKCwsJCgqiW7duyvuXG2+dToe/vz+2trYcOXKE2NhY0tPT+eCDD5rcodq2bZsyHrNmzWr2vF1rGo3muhz3ZlV7+VX+ET7VNE0WAFipzJhn1oF5Zh2aXf6I2ofHKvYDf3y2Fi9ezOLFiy95vB9++OHvNfgmJ9+HV0bGq+Vu1rG6ZBBeVNTwF8Lc3d2V2jVjtvBq8vX1xc/Pj3379lFYWEhiYqKSrTPeyjfWm3p6egINWVljzXBLderUCTMzMw4cOMDJkyfJysrCzs6O2tpaXn/9dSU7eiFj4NQcY9uKioqaZLeNNbp/9lfLUezt7SkoKKCqqgpA+R+46MOll9vGuN2F7xu/vnCf1dXVfPjhh8THx9OpUyelvvlCx48f5/Tp01hbWzeqEzYyGAxs3rwZaJwFB7Czs6O4uJj77ruPoUOHEhUVxbx584iNjVXGw9XVldWrV1NSUsI333zDzp07WbhwIVOnTm3RMcaMGUN4eDhJSUlKkLhy5UrlbsW2bdtYs2YNAQEBvP7662RkZPDmm28ye/ZsFi5c2OiuxnPPPUdgYCAWFhZs3bqV2NhYunbtymeffUZ0dDQDBw5k7NixbNq0iZUrVzJv3jxmzpyp7MPKyoo33ngDMzMzXnrpJTIyMjh69Ch9+/blhRdeoGfPnkrGvrCwkJ9//lnZ1vh/x44dmThxIiUlJTzxxBOkpqZSUFBAZWUlH3zwAZaWlsybNw9ra2tef/11vvjiC1xcXJQ7FPX19Xz66afs2LGDgIAApkyZ0ihIv9x4z5o1S/mZUF5ezlNPPUVubi6pqam0bdu20dgPGDCAAQMGKK8LCgqafD6uNWdn5+ty3JuVw/VuwE3A+HmSz1bLyVhdGRmvlrvRx+pid4kvGYQbb09nZ2djMBhQqVTKA5ZXk7EmvF27dixcuJDvvvuO3r174+DggIuLC5mZmWRmZhIYGEhWVhbQMMuJk5OTcqHQEsaa8EWLFrFz506++uorZs+eTUZGBunp6ZiZmTF//nxcXV15+eWXycjIwGAwACiZXeNrQKlp9vf3Z+bMmY2CkgvXu9BfLUfx9fWloKCAkydP0q5dO06dOgU0fPCMWfDMzEygIYAyNze/7DbGBypPnTqFwWDAYDAoF1jGUp2ysjJmzZpFcnIyffr04Zlnnmk2o7px40ZljC/MrBsdPHhQmaHlz1N43XLLLY3+kpyRcT+VlZVYWVkBDUFoeHg4O3fubPJZvNQxamtrCQ8PJzw8nPr6et59910A2rdvD6BcgHl6eqLT6QgICMDMzIzq6moKCgrw8fHBysqKysrKi7bT+CeqAwICsLCwUO4WGM/LheVPF9tHXV0dXbt2pWvXruj1eqZMmdKonRd71sC4j5MnT2IwGLC1tVUuWF1cXCgoKCAzM5NOnTqh1+uZP38+sbGxhIeHM2nSpEbn7HLjXVpaikqlUmZ8uZA8aCaEEEK0zCWD8E6dOmFtbU1OTg7Tp0/H3NxcqSO+Fnr37s0PP/xAVlYWmzZtYtSoUdx55518+eWXLF26lGPHjim32G+77bYrfjDTaMSIEezevZszZ86QkJCAt7c3KpWKuro65Y8o/DnAM97miI+P58svv6Rdu3bceuutuLq6cvr0aaZOnYqPj4+SyX/ttdeafXjvr5ajDB06lIMHD7JmzRrOnj2r1AYPGzZMWcf4F9nmzJmDr6/vZbeJiIjA09OT9PR0ZsyYQU1NDYWFhQQGBiplGLNnzyY5ORkbGxtsbGyU+W07duxIx44dgYZ6+tjYWNRqtfJA5p8ZLzwGDhyIRtP4Yzd06FASEhKUc3/o0CEA+vbtC8BXX32lPEBaU1NDbGwsAB06NL5VfKljrFq1ijNnzuDq6srJkydJS0vDyclJmVUlKCiIX375hb179wIND1nW1dUpwaxGo2HIkCGsXbuWhQsX0qZNG/bu3YtarVZmPwgKCiI9PZ2VK1eSkpKijLdxOsc2bdoQEhLC8ePHmTFjBlqtloyMDBwdHZUge9GiRVRUVNCqVSsSExPJycnBz89POcaAAQP48ccfSUhIYMGCBcrntFOnTkqJiLm5Ofn5+bz33ntYWVlx/PhxVCoVQUENU68tWbKE2NhYzM3NcXNzY9WqVUDDA66RkZGXHe+zZ88ya9Ys2rdvj4ODA0eOHEGv1+Pl5YWfn1+z518IIYQQjV3yL2bqdDomT56Mt7c3ycnJWFlZNaobveqNUau57777gIYHMisqKrjzzjt54okncHR0VIKeYcOG8dhjj/3l47i4uChBzY8//oiTkxPjx4/H3t6eo0eP4ufnpwQsRt27d6dDhw5UV1ezZcsWEhMT0Wq1vPnmm/Tq1YuCggJ27dpFVlYWvXv3vuoPqAUHB/PCCy8o09ap1WpGjRp1yXlmL7eNWq3mtddeo1OnTpw4cYIzZ87QrVs3Jk2apOzDeKehvLyczZs3K/X7ycnJyjpbtmyhvr6+0YwnFzp79ixHjx7F3Ny82faGhYXx3HPPYW9vz+7du7GwsGDMmDFKSUnbtm2pqqpi7969xMTE4OjoyAMPPNCopv9yx/Dy8iInJ4ddu3ZRWFhIr169mD59upLNjYyMZOzYsbi5ubF//34yMzNp3749r732mlIn/8ADDzBs2DDKy8uJiorCx8eHyZMn06ZNGwAeeeQR7rzzTszNzdm5cyd6vZ4+ffooc4BDw4VSz549OXXqFMePH+fWW29l6tSpyoPKPj4+nDlzhp07d1JZWcmAAQOUmVKg4Xvy9ddfJygoiOjoaIqKihgwYADPP/880HAX5JVXXiEoKIjk5GRlWsbnn39eKRMxntOamhq2bt2qnFPjxc/lxtvNzY0uXbpw5swZdu3aRU1NDX369OG///1vk4sfIYQQQjRPZbhY3YQQQlwDxpIyU7rR6wVvNA6+z15+pX+5c6kNfz9APlstJ2N1ZWS8Wu5GH6uLJWYvmQkXQgghhBBCXH0ShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWIShAshhBBCCGFiEoQLIYQQQghhYhKECyGEEEIIYWKa690AIYQQNxZN2eob+k9ACyHEP4FkwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxmSdcCPGv1WONx/Vuwg0p5Rn99W6CEEL840kmXAghhBBCCBOTIFwIIYQQQggTkyBcCCGEEEIIE5MgXAghhBBCCBOTIFwIIYQQQggTkyBcCCGEEEIIE5MpCoUQ4k/qygsp/uFFKhN/hjo9lv69aXXfR5i3DrroNtVnoji38b/oM+JQqc3QtrubVvfNx8zGEYDSXQso3b2AuvOZoDbH3LUttrdNxubWkabqlhBCiBuIZMKFEOJPCr8eTUXsN5i7BqNtcztVSb+Qt+RODLXNz59dW3CavCUDqT61C6uQwVh4daYi9msKvx79xzpFZzB3C8Om62NYeN2KPv0ghcsfpib/pKm6JYQQ4gYimXAhhLiAPiOBqqRfUFs70vr5Xag0FuQu6E316T2UH1yJrtu4JttUHt+MoboMy8B+OD/6LYb6ejLfcKYqaQv69INYeHem1X3zlPUNBgMZr7XCUHWeuuKzmLsEmrCHQgghbgQShAshxAX0mfEAmHuEo9JYAGDhHUH16T3UZCY0u43KXAtAbXEadaV51JXlUV9d/v/3dwgL784AVB7fQuWxjdRkHcZQdR5L/0gs/SOvcY+EEELciCQIF0L8q1WnxVBxcKXyWq1zBkBlqVPeU1nYAFBXmtPsPqw7jqBk+2xq81PInNq60bILt6lO3U/Z7k8a9mmuRRsyGMzMr05HhBBC3FQkCL/GcnNz+frrr0lKSqKyshJbW1u8vb15/PHHcXNzM2lb6uvrWbt2LTt27KCkpARPT08efvhhOnXqdNFt9uzZw8aNG0lNTaWuro6+ffsyYcIEZfmxY8f46quvyMvLo7a2FicnJ3r37s3w4cNRqVTKcX/88Ud27NhBQUEB1tbWdO7cmWeffRaAvLw8li9froyRo6Mjffv25YEHHkClUpGYmMjbb7/dpG0vvfQS3bt3p6SkhA8++ID09HQqKyuxs7MjPDycRx99FJ2uIZDKyMjgm2++ISUlhZqaGsLCwnjsscdwcXEBQK/Xs3btWvbu3cu5c+dwc3NjxIgRdO/eXTneokWLSExMJD8/H4C33nqL0NDQFo+VwWBg3bp17Nq1i6KiIqysrAgODmbs2LG4uroCsHLlSqKjo8nOzgbg2WefpV+/fso+Nm3axO7du8nJyaG2thZPT0+GDx9ORESE0s9FixaRlZWFXq/HwcGBLl26MHr0aCwsLFp0jLKyMlatWsXBgwcpKSnBx8eHRx55hHbt2inr/PLLL2zZsoX8/HwsLCwICAhg9OjR+Pr6XvSzdKOqyTlG6e8fKa8dH/4SAEN1mfKe8Wsz2+a/Z9VaO9xeSaDi4ApqC89g3jqEsugvqT65EzOdi7Kew13TsB/4BjW5x8j/7B7Ob/wvmlY+2ESMbna/Qggh/rnkwcxr7P333ycmJgYfHx/69euHr68vycnJnDt3zuRt2bBhA2vXrsXMzIyePXuSlZXFnDlzSE9Pv+g2Z8+eRa1WX/SCoaioCJ1OR69evejcuTN5eXmsWbOGnTt3Kut8/vnnfPvtt1RXV9O7d286dOhAXl6esnzRokXExMRga2tLZGQkRUVFrF69utE+ANq0acPgwYOVf8Y26fV6qqqqiIiIoE+fPuj1enbt2sXSpUsBKC8vZ/r06cTFxdGmTRvCw8OJjY1l1qxZ1NfXA7B8+XLWr1+PRqOhT58+FBcXM2/ePJKTk5XjJycn4+3tjUbT/LXr5cZq165drF69mqKiIiIjI7G1tSUmJoaFCxcq66SkpODi4oKtrW2z+4iJiaGiooKIiAh8fHw4ffo0H3zwAWfOnAEaAmgzMzO6d+9Ojx49KCkpYfPmzaxfv77Fx/j444/ZunUrdnZ2REZGkp6ezowZM5SLj8TERL744guysrLo2rUrrVu35tChQ8yZM6fZ/d3odN3G4TPfoPyz8OwIQE3WIQy11QBUpx8AwNyzAwB1ZQXU5CZRey5T2Y9KrUHX4z843P0eFj5dqD6zD1QqLNvcBkB9VWnDemYaLDzCMXcNbjhO/h+fMSGEEP8ekgm/hsrKykhLS8PGxoapU6cqmeGamhol+CsuLmb+/PlkZGRQUVGBtbU1HTp04PHHH8fGxqbZ/W7ZsoWcnOZvi7u5uTFo0KAm79fV1fHTTz8B8PLLL+Pv74+zszPff/89GzZsaJSxvdCoUaMAWLp0KZmZmU2WR0ZGEhn5R03r7NmzOXjwoBJkZ2dns337dmxtbXn//fexs7Nrso/c3FwAxowZQ+fOnamoqCA6OloJ+ow6dOjAyJFNp3NzdnZm9uzZymtvb2+WL1+ubH/ixAmKi4txcXHh1VdfBeCVV14hLS2NmJgYunfvTlRUFABPPfUU7dq1w8vLi2XLlvH9998r28yfPx+AcePGUVtbe8VjZTxnnTp14plnnuHgwYPMnj27UT/feustpX2lpaVN9jF27Fj8/f2BhjsML7zwArm5uSQmJuLn50dwcDDTp09X1rexsWHLli2NLnoudYzKykoSEhIAmDRpEi4uLlhZWbFp0yZ++uknxo8fr5wvPz8/Jk6cyNmzZ5k0aRJFRUXU1tZe9CLlZmHhdSvaoDuoOvEruR/3Q61zRn9mH2YO3th0bjjHpbs/oeSXt7EKuxeXJ9YDkD27PRbenVGZWVBx9Eeo06OLnIC5cwAAmW+6o21zG2b2ntQUpFCdvB1UarRBd1yvrgohhLiObu7fljc4rVaLVqulvLycyZMnExYWRkhICOHh4Wi1DQ9yVVZWotfr6dy5MxYWFhw5coQ9e/ag1Wp58sknm93v/v37OXbsWLPL2rVr12wQXlhYSGlpKSqVCj8/PwACAhqCg9TU1L/Vz5ycHLZs2UJRURHx8fFKOQk0ZE0NBgN2dna8++67ZGdn4+npySOPPKKUctx9990sX76cb775hgMHDhAXF4eLi0ujEgmAjRs3sn79ehwdHenduzcPPPBAo4Bv6dKlVFRUcODAAczNzRkyZAgA5uYNNbdlZWXk5uai0WgoLi4GIC0tje7duyulGqdPnyYwMJC0tDRl+dXSp08ftm/fTlxcHIsXLyY5ORkzMzPuv//+Fu/DGIAbGS8GHB0dlffKyspYu3YtpaWlREdHY2Njw8CBA1u0f41Gg1qtpq6ujtOnT2Nra6vcKTGORUREBO7u7pw5c4aPP/6YrKwsVCoVw4YNu+kDcCOnR1ZS/MMLVCZuhCw92qA7aHX/AlQay4tuY+4eRlXSL9RXl6JpdQu6Aa9h23+SslzbdgD69APUJf2CWmuHZUBf7G6bhFYezBRCiH+lf8ZvzBuURqPh6aef5tNPPyUtLY20tDQ2btyIvb09U6ZMITAwEA8PD5588kkOHz7M+fPn8fLyIjs7m8TExIvud9q0aVfcFmP5i6WlpZKRt7S0bLTsryosLGTTpk3K69DQUCXjXVJSAkBmZiahoaG0b9+e2NhYZs+ezbx583BycqJ9+/b4+PiQlpamZJBvvfVWHBwcAFCpVHh7exMQEEBNTQ0xMTGsW7eOuro6JfsMNGpDmzZt8PDwABouTIKCgjhx4gTPP/98s+Ny33338fnnn7N8+XKWL1/eZPnV4OzsTLdu3di6dSu//fYb0JBNDgz8a9PTLVu2jMLCQoKCgujWrZvyfkVFRaOxaNeuHc7Ozi3ap/HiZcOGDXzwwQeNlhnHQqfTERkZybp169i9ezcArVu3JiwsrNl9btu2jW3btgEwa9asFrflatJoNFd0XDOdM86PrLjocoe7puFw17RG77mMX3fJfRoz5jeDKx2vfzMZq5aTsboyMl4td7OOlQTh11jPnj2JiIjg2LFjJCUlsX37ds6fP8+6deuYMmUKe/bsYcGCBU22Mwavzfkr5SjGgLa6upr6+nrUajVVVVWNlv1VoaGhfPfddxQVFfHpp5+ye/duzM3Nefrpp5Vg3MrKijfeeAMzMzNeeuklMjIyOHr0KL1792bGjBkUFxczceJEIiIiWLBgAVu3bkWr1TJmzBhCQkIaBYS//vorn332GdHR0Y2C8NWrV1NRUcGGDRv4/vvvmTNnDgsWLMDMzIy33nqLqKgoMjIycHZ25vjx4+zZs0dp38CBA/H39+fQoUMYDAYcHR1ZsmRJs+Uzf9Xq1avZunUrERERTJw4kdjYWBYsWMDMmTNZvHgxanXLHtGor6/n008/ZceOHQQEBDBlyhTMzMyU5a6urqxevZqSkhK++eYbdu7cycKFC5k6dWqL9j9mzBjCw8NJSkpq9DCncSy2bdvGmjVrCAgI4PXXXycjI4M333yT2bNns3DhwiZjNmDAAAYMGKC8LigoaFE7riZnZ+eLHNfD5G25GdTW1l6X83QzuvhnS/yZjNWVkfFquRt9rIxJwT+TIPwaqq2t5eTJkwQHB9OxY0c6duyIra0ty5YtUwLgffv2AQ2Byvjx44mJiWH+/PkYDIaL7vevlKM4OTmh0+koKytTSi5OnToFwC233AI0BOgFBQWo1Wrc3d1b1MfKykqsrKxQqVQ4OTkRHBxMfHy8MvOGcd/N0Wq1lJWVKaUhbdu2RavV4uvrS2xsLBkZGUBDzXjr1q2VDL6RMWg1tgHA2tqaTp068f333yszthhLJHr37g00XOCsWrUKgPbt2wMN5yowMFDJShsfljQuvxqM/fH19UWr1dK2bVug4bmA8vLyiz4oeSG9Xs/8+fOJjY0lPDycSZMmKaVN0HgsjLPE7Ny5UzkfLVFbW0t4eDjh4eHU19fz7rvvAn+MhbE8xdPTE51OR0BAAGZmZsrn52peuAghhBD/VBKEX0O1tbW8+eabeHp64ufnh4WFBQcONMyyYAxojFno+Ph4PvvsM+Lj4y+7379SjmJmZsbdd9/NqlWrmDdvHiEhIURFRaFWqxk6dCgAJ0+e5O2338ba2lqZWSQmJoYDBw5w8mTDn9ZOSkpi4cKFBAcHc/vttzN37lzq6urw9PSkrKyMgwcPAg0PUUJDWUhISAjHjx9nxowZaLVaMjIycHR0pH379lhbW+Pu7k52djZz584lICBAeUgyOLhh9oh169Zx4sQJ2rZtS11dHTExMQDKA6E//fQT0dHR+Pv7o1ariYuLAyAsLEwJwN999110Oh02NjYkJCRQWlpKp06dlBKKbdu2sWfPHnx8fEhPT+fEiRNYW1szfPhwZQyXL19OaWkp1dUNM2asX7+enTt3MmzYMDw9PS87VkFBQcTFxbFx40aKioqUiyBPT08lAF+/fj2ZmZnKFf327dtJTEzk9ttvJzg4mCVLlhAbG4u5uTlubm7KxURgYCCRkZF89dVXZGRk4OPjQ01NDbGxsY3OR0uOsWrVKs6cOYOrqysnT54kLS0NJycnBg8eDEBQUBC//PILe/fuBRoukurq6rC1tcXT0/OKP5tCCCHEv5EE4deQsb42MTGR+Ph49Ho9jo6ODBw4kHvvvReA4cOHk52dTXJyMqdPn+a+++7jq6++uibtGTZsGHq9nt9++429e/fi5eXFQw89hI+Pz0W3SU1NZdeuXcrr3NxcZXaM22+/nXbt2vH7779z8uRJNBoNHh4e9O3bV3koEuD//u//WLp0KfHx8ajVam699VbGjh2LtbU1AFOmTGHFihUkJyeze/duHB0dueuuu5SLgy5dupCXl0dcXBx6vR5XV1duv/12JSj09fXl4MGDxMTEUFtbi6OjI7169WoUQPv4+BAVFUVZWRkODg7ce++9jBgxQlnu5uZGWVkZu3btQqPR0KlTJ0aPHt1ousE/z9hy6NAhAPr164enp+dlx2ro0KFUV1ezd+9edu/ejZWVFV26dGHMmDHKNgkJCY3ucpw4cYITJ04QGhpKcHAwRUVFQMMMO1u3blXW69u3L5GRkbRt25aTJ08qAbKzszPdu3dv9PDn5Y7h5eVFVFQUx48fR6vV0qtXL0aPHq3MuR4ZGcm5c+fYvn07+/fvx8LCgvbt2/Pwww8rzxkIIYQQ4tJUhkvVPQghxFWWlZVl8mNerF6wxxqpCW9OyjP6G7q+8kZyo9ei3khkrK6MjFfL3ehjdbGacPljPUIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiY5no3QAghrpeoEVnXuwk3KOfr3QAhhPjHk0y4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJibzhAshxP/XY43H9W7CDSHlGf31boIQQvzjSSZcCCGEEEIIE5MgXAghhBBCCBOTIFwIIYQQQggTkyBcCCGEEEIIE5MgXAghhBBCCBOTIFwIIYQQQggTkykKhRDiMurKCyn+4UUqE3+GOj2W/r1pdd9HmLcOuug2Vck7OL/5TfTZR6G+Fo1rW+wHvIZ1xxEAnH1R1ex2Nl0exWn00mvRDSGEEDcQCcKFEOIyCr8eTVXSL1jc0h0znQuViT+Rt+ROPF5PRqWxaLJ+fXU5+Z/fg0FfgWWb21Bb2VN5+AcKlj2Eu1cnzJ0DsO3zQqNtymKWYqg6j8Yl0FTdEkIIcR1JEC6EEJegz0igKukX1NaOtH5+FyqNBbkLelN9eg/lB1ei6zauyTZ1pTkY9BUAuDzxI2pLHRmvO1NfXkhd8VnMnQNodf/8P46RdYTS3z8CjSW6nk+ZqGdCCCGuJ6kJF0KIS9BnxgNg7hGuZL0tvCMAqMlMaHYbc+cArMLvAyD/83vJ//J+6ssLsWx7O5b+vZusX7prPgA2nUdjpnO5yj0QQghxI5JM+GVMmzaNY8eO8eyzz9KvX7/r3RwhxDVWnRZDxcGVymu1zhkAlaVOeU9lYQM0ZLwvxibiEapP/U51yg5le+vw+1GZNf6xW1eWT0Vcw/Fs+754VfoghBDixndTB+G5ubl8/fXXJCUlUVlZia2tLd7e3jz++OO4ublddvuRI0decvknn3xC9+7d8fX1xcvL62o1+6L27NnDggULABg8eDDjxo276sc4evQoK1as4OzZs9jY2NCnTx8efvhhzMzMml2/qKiI//3vfyQnJ1NeXg7A6tWrG60zffp00tLSKC8vR6fTERQUxNixY3F1dVXWOXbsGN999x2nT58GwNPTk4kTJ+Lh4aFc6PyZi4sLCxcuZOfOnSxatKjZ9r311luEhoYCcPbsWVasWEFSUhJ1dXW0bt2a//znPwQHB3P69GlWr15NamoqpaWl2Nvb07NnTx588EHMzc0ByMjI4JtvviElJYWamhrCwsJ47LHHcHFpyEzu27ePNWvWUFBQoLTvzjvv5M477wQgLy+P5557rkkbx4wZw9ChQwEoLS1l6dKlxMXFUVtbS3BwMI899hgeHh7K2K5du7bJPj7//HPs7Owuez7Ky8v54osvSElJobi4GCsrK9q1a8cjjzyCs3NDMLlp0yZ2795NTk4OtbW1eHp6Mnz4cCIiGrK7CxcuZNeuXc2O9+rVq0lMTOTtt99udvk/4WK1JudYQ2nI/+f48JcAGKrLlPeMX5vZNv9zRp+dSMFXD6CysMH9teOotfbkzO9O8doJaBx9sWo3WFm3bO8SDDVVWLa5DQuP9teiS0IIIW5AN3UQ/v7775OWlkZYWBju7u4UFhZy/Phxzp0716IgfPDghl+ENTU1/PrrrwD069cPa2trAKytrRk0aNC168AFCgsL+eKLLzAzM6Ouru6aHCM/P5+ZM2dSX19Pjx49OHXqFBs2bECtVjNq1KhmtykpKSE7O5uAgAAOHz7c7DpFRUV07NgRCwsLDh48SExMDKWlpUqgdvz4caZPn059fT2dO3fGwcGBtLQ0SktLAZQLHaMjR46Qnp6unEMvLy/lXBmPt3//flQqlRLoZ2VlMXXqVCorK2nfvj2tW7cmOzubwsJCoCFAP378OKGhoWi1WqKiotiwYQP19fWMHTuW8vJypk+fTnFxMZ06dUKj0RATE0Nubi5z585FrVZTUFCAi4sL7dq1o7CwkLi4OL744gs8PT0JCwtT2ufp6UmHDh2U1/7+/srXCxYs4NChQ7Rp0wY7OzsOHjzIjBkz+Oijj9Bo/vh27NatG05OTsprCwuLFp2P8vJy9u3bR0hICKGhocTGxhIVFUVOTg6zZ88GICYmhoqKCiIiIsjKyiIlJYUPPviA9957Dz8/Pzp06ICNjY2yz5MnT5KcnEzr1q0BcHJyanQ+qqqq2LGjIdvbku+7G52u27hGdd76jIZylJqsQxhqq1FpLKlOPwCAuWfDea4rK6C+vACVpS0aB09qc4+DwYDa2gnz1sEAaBx9qSs+S03ucSUIN9TqKdu7GAC7fv9nqi4KIYS4Ady0QXhZWRlpaWnY2NgwdepUVKqG6b5qamqor68HoLi4mPnz55ORkUFFRQXW1tZ06NCBxx9/HBsbGyXTXF5ergThw4cPb5TB/XM5ijFL2KdPH0pKSkhMTCQkJISnnnqKZcuWcejQIXx8fHjhhReU/RgztKdOncJgMBASEsK4ceOUzKTBYGDhwoW0atUKHx8f9u3bd8m+nzx5kj179lx0+fDhw9HpdE3e37hxIzU1NQwaNIjx48eTk5PDxIkT2bx5M/fffz9arbbJNr6+vixYsIDU1FQmT57c7PHmzZunfB0dHc0HH3xAXl6e8t63335LXV3dRbOkF17o1NbWMmHCBADuuusuAAIDAwkM/GPGiOXLlwPQpUsXJUu9bt06KisrGT58eLN3OIKDg1m8eLFygeXm5sbatWuVQPbEiRMUFxfj4uLCq6++CsArr7xCWloaMTExdO/enaFDhyoZbYBJkyZx9uzZRn01tre5uxipqakcOnQInU7H22+/jUaj4c033yQpKYk9e/Y0GptBgwYpGf4LXe586HQ65s2bh7u7O4CStT5z5gxlZWXodDrGjh2rXBjU19fzwgsvkJubS2JiIn5+fkRGRhIZGans0zgexvPh5ubWqH+bN28GwM/Pj+Dg4CZtutlZeN2KNugOqk78Su7H/VDrnNGf2YeZgzc2nRsuXkt3f0LJL29jFXYvLk+sb6gZ11hSV5xG3pK7UGvtqD71O6hUWPr1UvZdEf8ddSXZaFzaoG035Hp1UQghxHVw0wbhWq0WrVZLeXk5kydPJiwsjJCQEMLDw5VgsrKyEr1eT+fOnbGwsODIkSPs2bMHrVbLk08++beOv3v3brp164ZOp+Pw4cO88sor+Pv74+rqSkpKCqtWrWLixImcO3eOt956i6qqKjp37oxarWb//v1kZmYyZ84czM3N2bhxI0lJSbz33nts3LjxssfOyMhg06ZNF10+ePDgZoPwM2fOAH9kZt3c3LCxsaG8vJycnJxG2egrtXbtWoqKioiLi0OtVivBql6vJzk5GWjIwH711VdYW1vTv39/hg8fjlrd+Nngffv2UVxcjJubG506dWpynAuzrkOG/BG0HD16FIBTp04xfvx4zMzM6NGjB6NHj8bS0rJJhra2thZAyTYbS1LKysrIzc1Fo9FQXFwMQFpaGt27dwcaLoB2795Nbm4uZ8+exdPTky5dujTa9/79+9m3bx92dnZ06dKFhx56CGtra2X8b7nlFiXr7e/vT1JSEqmpqY32MXfuXGpra3F3d+fee+9tFBRfirW1tXKhcWE/ra2tle+LCzPzF67j6OjYZH/Hjx/n9OnTWFtbc9tttzVZbjAYlCD8wvPxT+P0yEqKf3iBysSNkKVHG3QHre5fgEpj2ez6GidfXB5fz/mt06lOjQJDHeZet2LXfxKWvt2V9YxlL7Z9JiqJBCGEEP8ON20QrtFoePrpp/n0009JS0sjLS2NjRs3Ym9vz5QpUwgMDMTDw4Mnn3ySw4cPc/78eby8vMjOziYxMfFvHz8sLIyXXnpJqeG1sLDgjTfeIC4ujjlz5ihB1e+//055eTmenp5K5tvOzo7MzEwSExNxdHTk22+/ZeTIkS0Ogvv16/eX6m7Pnz8P0CjjbWlpSXl5OefOnbvi/V3ot99+Iz8/H2gox/Dz8wMaglrjnYkzZ87Qo0cPoqOjWbt2LTY2Nk0CN+PFxV133dUkQDcep6KiAj8/P0JCQpT3S0pKAEhOTqZbt24kJCSwZcsW1Gp1k6x0UlISGzduxNzcnAcffBCAdu3aERQUxIkTJ3j++ecbrX/h2GRkZChBp0qlomPHjlhZWSnLW7duTdu2bTEzMyMmJoYtW7ZQWlrKCy+8oIy/peUfgZvxXBiPYWZmRkhICJ6enuTn53Po0CEWLFiATqejY8eOzQ39RZ07d44vv2yoZ3744YcblbsYLVu2jMLCQoKCgujWrVuT5caLwttuu63ZOyUHDx4kJyeHVq1a0bNnz2bbsW3bNrZt2wbArFmzlO8DU9JoNH/ruGY6Z5wfWXHR5Q53TcPhrmmN3rMKGYRVyKXL2dxejv3LbbqW/u54/ZvIWLWcjNWVkfFquZt1rG7aIBygZ8+eREREcOzYMZKSkti+fTvnz59n3bp1TJkypdGDjhcyBmx/h6enJ4BSO+vm5oZarVYCsurqagClVCEzM5PMzMxG+8jJySElJYXa2lqOHz9OUlISaWlpAMTGxmJhYdFsrfZfLUext7cnKyuLqqoq5T3j1w4ODi3q98UsXLiQqqoqfv/9dz7//HNmz57N4sWLsbOzQ6VSYTAYGDt2LD169MDDw4NvvvmG2NjYRkH4hVnX/v37NznGpbKudnZ2FBcXc9999zF06FCioqKYN28esbGxjYLwuLg45s2bh0qlUu5eQEPw+9ZbbxEVFUVGRgbOzs4cP36cPXv2YGdnp2zfr18/+vTpQ15eHvPmzWPjxo3Y2tpy//334+Liwscff6ys27NnT9577z0OHDhAfX099vb2wB+fDWg6/vfffz8PPPCAsnz+/Pns27ePmJiYKwrCc3JymDFjBrm5uTz44IPKw6NG9fX1fPrpp+zYsYOAgACmTJnS5OHcvLw8YmNjUavVF302wnjRdMcddzQb5AMMGDCAAQMGKK+ND7aakrOzcwuP63HN23IzqK2tvS7n6WbU8s+WkLG6MjJeLXejj5Vx8oU/u2mD8NraWk6ePElwcDAdO3akY8eO2NrasmzZMiWwMdZWDxgwgPHjxxMTE8P8+fMxGAx/+/h/ztI2l7UFlLrwrl27MmnSJOX9c+fOYW1tzfr16zEYDMTHxzfaLi8vTynj+LO/Wo7i6+vL8ePHOXnyJP369SM7O5uKiopG5Ro5OTnU1dXh5OTUbObzz6qqqrC0tESlUqHVaunSpQuff/455eXllJSU4OrqioeHR5MLEKDJ/v9O1vWWW25Rykcudozff/+dxYsXY2Vlxauvvkrbtm2brN+7d8McziUlJaxatQqA9u0bZqyorKzEysoKtVqNm5sbAQEBnDlzhqysLKAhuGzVqlWTYNRYZmC805GamkpNTQ3m5uacOnVKaT80zPjT3MONV1KqkJqayowZMygpKeGJJ55g4MCBjZbr9Xrmz59PbGws4eHhTJo0qdnx3rJlC/X19XTr1q3RcxJGZ8+e5ejRo5ibmzc5hhBCCCEu7aYOwt98802l9MHCwoIDBxpmLDAGTcbsYnx8PJ999lmTQNcUIiMj+eGHH4iJiWHGjBm4uLiQm5vLsWPH+Oijjxg5cmSjBwmND35eaorCv1qOMmTIEH799Ve2bdtGRUWFEgDeeeedShA2ffp08vPzmTRpEl27dqWkpISvv/6asrI/pmdbuHAhABMmTGD//v2sW7eONm3aYGlpqTzo6OHhoTw0OXToUBYvXszy5cs5dOgQ0dHRAPTt21fZ54VZV+MDgH9mvPAYOHBgk0B36NChJCQk8MMPP5CVlcWhQ4caHePQoUMsXLgQg8FAYGAg+/btUy7SjOP87rvvotPpsLGxISEhgdLSUjp16qTMfPLqq6/i6uqKq6urUv8OKBnq3377jR07dhASEoK5uTkxMTEA9OrVC7VajZ+fH+Hh4Rw+fJhp06Zha2vLiRMncHJyUmq+p0+fjoODAz4+PhQUFHDo0CFUKhW9ejU8zHe581FaWspbb71FZWUl3t7eZGVlsXTpUqDhYU83NzeWLFlCbGws5ubmuLm5KRcbgYGBSjsuVnt/IeNFU+/evRvdLRBCCCHE5d20Qbi5uTlDhgwhMTGR+Ph49Ho9jo6ODBw4kHvvvRdoKMvIzs4mOTmZ06dPc9999/HVV1+ZtJ2Ojo5MmzaNb7/9llOnTpGUlISzszN33nmnyQMXV1dXXnvtNVasWMH+/fuxsbHh7rvv5qGHHrroNlVVVU3mjDa+njBhAu7u7tjZ2SnnwN7env79+zNixAgle9u/f3/Ky8vZvHkzu3fvxs3NjUcffVR52BEaZ12NwfuFLsy63nHHHU2Wh4WF8dxzz/H999+ze/dunJ2dGTNmjBJAFhcXK3dAEhISSEhIULY1BuE+Pj5ERUVRVlaGg4MD9957LyNGjFDWa9++PfHx8SQmJmJpaUlAQAADBw5UAtewsDBSUlI4cuQIlZWVODk5MWjQIO6//35lHxMnTmw0T3h4eDiPPfaY8mDo7bffTlRUFHv37kWtVhMUFMR9991Hu3btWnQ+KisrqaysBCA9PZ309HRlvS5duuDm5kZRURHQMJPQ1q1bleV9+/ZV+rJz504qKirw9/dvdsaTkpISpSTqwukKhRBCCNEyKsPVqM0QQogWMpbvmFJL6wV7rJGacICUZ/Q3dH3ljeRGr0W9kchYXRkZr5a70cfqYjXhzRcyCyGEEEIIIa4ZCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxCcKFEEIIIYQwMQnChRBCCCGEMDEJwoUQQgghhDAxzfVugBBC3CiiRmRd7ybcIJyvdwOEEOIfTzLhQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJgE4UIIIYQQQpiYBOFCCCGEEEKYmAThQgghhBBCmJjMEy6EEFdJjzUe17sJV0XKM/rr3QQhhPjHk0y4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJiZBuBBCCCGEECYmQbgQQgghhBAmJkG4EEIIIYQQJibzhAshxDVUV15I8Q8vUpn4M9TpsfTvTav7PsK8ddAltyvb9ymlvy+gJj8FtaUNFt4RuD6zVVmuzzrCuZ9fpfrUbqivRePkT6uRS9D6R17rLgkhhLgKJAgXQohrqPDr0VQl/YLFLd0x07lQmfgTeUvuxOP1ZFQai2a3Ob9tFud/fg2V1g7rWx9EpTajOjVKWV6Tl0zuR70wVJeibTsAjXMANXknqDuXYapuCSGE+JskCBdCiGtEn5FAVdIvqK0daf38LlQaC3IX9Kb69B7KD65E121ck23qq0oo2TodzCxw+7+YZjPm57dOx1Bdit2db+Fw17Rr3xEhhBBXndSECyHENaLPjAfA3CNcyXpbeEcAUJOZ0Ow21an7MegrMNM5U/TdE6RPtiF7VigVCWv/WCd5e8P+0w+Q8V8nMqa6UbTueer1FdewN0IIIa4mCcIvY9q0aYwcOZKdO3de76YIIW5w1WkxFH//ovKv7nwmACpLnbKOysIGgLrSnGb3UV9e0LD8fBaGmiqs2g+jJjeJguUPoU8/2LDs/69TfWYfVuH3o1JrKNv9Ced//u8165sQQoir66YuR8nNzeXrr78mKSmJyspKbG1t8fb25vHHH8fNze2y248cOfKSyz/55BO6d++Or68vXl5eV6vZTSxZsoQTJ05QUFCAubk5bdq0YfTo0fj4+Fz1Y6WmprJs2TKSk5OxtLSka9euPProo1hZWTW7vl6v56OPPiIlJYVz584BDePi6uqqrPPJJ59w5MgRSktLsbKywt/fn1GjRuHn5wfApk2b2L17Nzk5OdTW1uLp6cnw4cOJiGjICJ4+fZrVq1eTmppKaWkp9vb29OzZkwcffBBzc/MWjZFer2ft2rXs3buXc+fO4ebmxogRI+jevbvSzry8PJYuXcqRI0dQq9V06NCB8ePH4+DgAEB9fT1r165lx44dlJSU4OnpycMPP0ynTp0ASExM5O23324yRi+99JJynKioKNavX09WVhZmZmZ4e3vz4IMPEhYWpqx/7NgxvvvuO06fPg2Ap6cnEydOxMPDo0XHiIuLY+3ataSnp6PVaunRowdjxozBwqIh07pw4UJ27drVaHtLS0u+/vpr5XV+fj4rVqzg8OHDVFdX4+TkxKhRo+jevTt5eXl8/fXXnD59mnPnzqHT6ejUqROjR49Gp/sjmLxUP/6tanKOUfr7R8prx4e/BMBQXaa8Z/zazLb5n1FqnYvytctTmzDTuZBXeY6qY5uoTNyIhXdnzHQu1J3Pwv6O/2J32ytUJKyhYOlIKhI30Or++degZ0IIIa62mzoIf//990lLSyMsLAx3d3cKCws5fvy4EoRdzuDBgwGoqanh119/BaBfv35YW1sDYG1tzaBBg65dB/6/HTt20KZNG3r16sWRI0eIj48nLS2NBQsWKIHV1VBZWcm7775LSUkJ3bp1Iy8vjx07dlBVVcWLL77Y7Da1tbWcPn2agIAADh482Ow6BQUFtGvXDmtra44ePcqhQ4fIzMxk0aJFAMTExFBRUUFERARZWVmkpKTwwQcf8N577+Hn58fZs2c5fvw4oaGhaLVaoqKi2LBhA/X19YwdO7ZFY7R8+XK2bt2Ku7s7ffr0ITo6mnnz5jF9+nTatm1LfX09s2bNIiMjgw4dOlBTU8P+/fspLCxkxowZAGzYsIG1a9fi4uJCz549iYqKYs6cOcydOxdvb2+lv23atKFNmzbKa+NnLScnh/nz52MwGOjSpQtVVVUcOXKEWbNm8fnnn6PVajl+/DjTp0+nvr6ezp074+DgQFpaGqWlpY3G9GLHSE5OZs6cOZiZmdGzZ08yMzPZsmULdXV1/Oc//2m0jws/yxrNH9/qJSUlTJ06laKiItq2bYuPjw8FBQXk5eUBDQF6XFwcoaGhhIaGsn//frZv305paSmTJk0CaHE//m103cY1qvPWZzSUo9RkHcJQW41KY0l1+gEAzD07AFBXVkB9eQEqS1s0Dp6Yt24HajOor2uyf2NG3dw9nLrzWU2Wqy10Td4TQghxY7ppg/CysjLS0tKwsbFh6tSpqFQqoCGgrq+vB6C4uJj58+eTkZFBRUUF1tbWdOjQgccffxwbGxvGjRsHQHl5uRKEDx8+vFGWd9q0aRw7doxnn32Wfv36KVnGPn36UFJSQmJiIiEhITz11FMsW7aMQ4cO4ePjwwsvvKDs5+zZs6xYsYJTp05hMBgICQlh3LhxODs7AzBr1iz8/f2Bhmztc889R1FRERkZGcr7F8rJyWHLli0XHZtBgwY1exFizPB26tSJl19+maqqKh5//HGioqJ4+OGHad26dZNtrK2tWbx4MeXl5Tz22GPNHm/atGnK16dPn+bVV1+lsLCQ2tpaNBoNY8eOVfpRX1/PCy+8QG5uLomJifj5+REcHMzixYuVgNHNzY21a9dy+PBhZb+XG6OoqIaZI5566inatWuHl5cXy5Yt4/vvv+fVV18lNjaWjIwMfHx8eP3116mvr+f5558nJSWFxMREgoOD+emnnwB4+eWX8ff3x9nZme+//54NGzYwYcIEpS0dOnRo9i5Kfn4+BoMBW1tbXnnlFaqqqhg7dix6vZ6SkhK0Wi3ffvstdXV1yufpYi52jOjoaOrr6+nTpw/PPvuscl527NjBiBEjlKw+NP0sG23atImioiL69u3bqF9G7u7ufPLJJ7Rq1QqAdu3asWjRIo4cOaKs09J+/NtZeN2KNugOqk78Su7H/VDrnNGf2YeZgzc2nUcBULr7E0p+eRursHtxeWI9GgdPbDqPpvzAcvL/NxiNa1uqjm9BZanDOvx+AOxun0xV0hZKts2kJi+ZqqSGnwc2XR+9bn0VQghxZW7aIFyr1aLVaikvL2fy5MmEhYUREhJCeHg4Wq0WaMj86vV6OnfujIWFBUeOHGHPnj1otVqefPLJv3X83bt3061bN3Q6HYcPH+aVV17B398fV1dXUlJSWLVqFRMnTuTcuXO89dZbVFVV0blzZ9RqNfv37yczM5M5c+Zgbm7eKNCura0FQK1WK0HQnxUWFrJp06aLtq1Lly7NBuFnzpwBICAgAGgYQ09PT1JTU0lLS2s2CG+pLVu2kJGRoQRq99xzj5J9/fOFhLGPjo6OAE3aalzu5OSkvHe5MTLeMTh9+jSBgYGkpaUBKP+npqY22o9arcbX15f8/HxSU1NxcXGhtLQUlUqllNEYx8m4rdHGjRtZv349jo6O9O7dmwceeACNRkNISAht2rQhJSWFuXPnUlVVBUCfPn1wdXVFr9eTnJwMNNwd+Oqrr7C2tqZ///4MHz4ctVp92WMYy3OysrKoqKjg1KlTANTV1ZGRkdEoCJ8yZQp1dXV4e3szcuRIOnRoyLwePXoUaLhI/c9//kNdXR0dO3Zk3Lhx2NnZKeflYufrSvohwOmRlRT/8AKViRshS4826A5a3b8Alcbyotu0Gr4IlUZLxeF11OSdwNI/Eod7ZqNx8gVA26Y/TmO+5vzWdymP/RpNKx8chs7Ftu//mahXQggh/q6bNgjXaDQ8/fTTfPrpp6SlpZGWlsbGjRuxt7dnypQpBAYG4uHhwZNPPsnhw4c5f/48Xl5eZGdnk5iY+LePHxYWxksvvcTq1atZu3YtFhYWvPHGG8TFxTFnzhwlcPv9998pLy/H09NTyXzb2dmRmZlJYmIiHTt2VPZZVVXF4sWLAbj77rsvGoSHhoayevXqK27z+fPnAZSLFGioFQaUeu+/av/+/Rw7dgxoCJ6Dgpr/QyTLli2jsLCQoKAgunXr1mR5UlISGzduxNzcnAcffLDJ8ouN0X333cfnn3/O8uXLWb58ubK+sV/G/y/Wd+NyS0tL5a7Kn8dGpVLh7e1NQEAANTU1xMTEsG7dOurq6hg1ahQajYZ+/fqRlpbGgQMNJQf29vZ07twZaLh7Y7xLc+bMGXr06EF0dDRr167FxsaGIUOGXPYYAwYM4NdffyU5OVm5k/PnvpqbmxMeHo6rqyvp6emcOHGC2bNnM2vWLHx8fJSSkePHj9OrVy+Sk5PZs2cPVVVVTJ48udE+s7Ky+Pbbb1GpVIwZM6bF/bjQtm3b2LZtG9BwR8P4fWBKGo3muhwXwEznjPMjKy663OGuaU2mGVRb2uD44P9wfPB/F93OJmIMNhFjrlYzG7me43WzkbFqORmrKyPj1XI361jdtEE4QM+ePYmIiODYsWMkJSWxfft2zp8/z7p165gyZQp79uxhwYIFTbYrKSn528f29PQEwMamYaYDNzc31Gq18oBjdXU1gFJnm5mZSWZmZqN95OT8MTtCSUkJM2fO5NSpU9x+++2MHj36osf+q+Uo9vb2AEqG9sKvL8yg/hXTpk1Dr9dz6NAh3n//fT788EMWLFiAi0vDQ2b19fV8+umn7Nixg4CAAKZMmYKZmVmjfcTFxTFv3jxUKpVyZ+FClxqjgQMH4u/vz6FDhzAYDDg6OrJkyRLs7Owa9e9ifTcur66upr6+HrVa3WRsQkJC+OCDD5Ttf/31Vz777DOio6MZNWoU8fHxfPbZZzg7O/Puu+9SVVXFq6++yvz58/Hy8sLd3R2VSoXBYGDs2LH06NEDDw8PvvnmG2JjYxkyZMhlj+Hs7Mz8+fPZu3cvxcXFBAQE8PXXX5Obm6v09T//+Y9yIQHwxhtvkJyczMGDB/Hx8cHOzo7s7Gz69+/PE088wcmTJ/nvf/9LQkICdXV1ynk5efIkM2fOpLy8nGeeeUa5mLCzs7tsPy40YMAABgwYoLwuKCho/kN0DTk7O5vouP+Mh1Jra2uvy3m6GZnus3Xzk7G6MjJeLXejj9XFJiy4aYPw2tpaTp48SXBwMB07dqRjx47Y2tqybNkyJXjat28f0BAEjB8/npiYGOXBub/rz7fcL3YL3liT27VrV+WhNmjIWhproPPz83n33XfJzs5m2LBhjBo16pLH/qvlKL6+vvz++++cPHkSaCjXycrKQqVSKbOMFBQUUF1djb29faOZMC5Gr9ej0WhQq9VYWFjQsWNHtFotlZWV5Obm4uLigl6vZ/78+cTGxhIeHs6kSZMaZaSh4Y7B4sWLsbKy4tVXX6Vt27aNll9ujGprawkMDCQwMBBomCEEoH379krfAaUu32AwKOU5t9xyC05OTuh0OsrKypSSFmOpxy233AI0zMbTunXrRgEu/HHu09PTAXBxcVFKN2xtbamqqiIzMxNvb288PDyaXIzBHxn6yx3DYDA0emD46NGj5ObmYmlpqTzImZub2+z5N+7Tx8eHEydONFlubm6uHOfw4cO8//771NXV8fLLL9OlSxdlPY1Gc9l+CCGEEOLSbuog/M0338TT0xM/Pz8sLCyUEgBj4GXMYBozlPHx8SZvZ2RkJD/88AMxMTHMmDEDFxcXcnNzOXbsGB999BGurq688cYbFBcX4+zsjF6vZ+nSpcq2xqDyQn+1HOX222/nhx9+ID4+ng8++IC8vDxqamro0aOHErR98sknHDt2jEcffVTJaC5cuFCpCwb4+uuv0Wq1PPLII6Snp7NgwQJCQkKwsbFRpou0s7NTMtlLliwhNjYWc3Nz3NzcWLVqFQCBgYFERkZy6NAhFi5ciMFgIDAwkH379ikXUMaSi8uN0bZt29izZw8+Pj5KCYa1tTXDhw8HICIiAk9PT9LT05kxYwY1NTUUFhYSGBioTB949913s2rVKubNm0dISAhRUVGo1WqGDh0KwLp16zhx4gRt27alrq6OmJgYpQ0AQUFBqFQqjh8/zocffkh1dTX5+fmYm5sr9eVDhw5l8eLFLF++nEOHDhEdHQ1A3759W3SM6upqXnzxRcLCwhotHzFihHIX5oUXXqBdu3a4u7uTnp7eaDpKgCFDhrBjxw5+++039Ho9KSkpShtUKhXp6enMmjWL2tpagoKCSExMVEq4hg8fjk6nu2w/hBBCCHFpN20Qbm5uzpAhQ0hMTCQ+Ph69Xo+joyMDBw7k3nvvBRoChuzsbJKTkzl9+jT33XcfX331lUnb6ejoyLRp0/j22285deoUSUlJODs7c+eddyrlA8XFxUBDFvrCDLevr2+zQfhfZWVlxRtvvMGyZcuIi4vDwsKC/v378+ijl55R4c9zThsDrhEjRtCqVSvc3d05fPiwEnx3796d4cOHK5n+oqIioGHmmq1btyr76du3L5GRkRQXFyt3JxISEkhISFDWMQbhlxsjNzc3ysrK2LVrFxqNRpnX2nhxoVaree211/jyyy9JTExEpVLRrVu3RjO+DBs2DL1ez2+//cbevXvx8vLioYceUu4SdOnShby8POLi4tDr9bi6unL77bcrU10GBQUxYcIEfv75ZxISElCpVLRt25bhw4crZTn9+/envLyczZs3s3v3btzc3Hj00UeVOcAvdwwzMzNat25NbGwser0ed3d3hgwZwm233ab046677iIhIYGTJ09iYWFB+/btGTlypHI7zMPDgylTpvDtt9+yd+9eHBwcGDZsmHLBUlJSolx0nThxolHWfPDgweh0usv2QwghhBCXpjJcjdoMIYRooayspvNbX2umqhfsseafUROe8oz+hq6vvJHc6LWoNxIZqysj49VyN/pYXawmXOYSE0IIIYQQwsQkCBdCCCGEEMLEJAgX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CBdCCCGEEMLMJIQLIYQQQghhZjJPuBBCCBPVusk4teDxL6V+0oJHF0II85CRcCGEEEIIIcxMQrgQQgghhBBmJiFcCCGEEEIIM5MQLoQQQgghhJlJCBdCCCGEEMLMJIQLIYQQQghhZhLChRBCmI3eWMOrNcfpULUbl6p/MbL6AIdri5q17bZt2/D09MTT05N//OMfyvK1a9dy55134ufnR0BAAOPGjWP79u236hSEEOKmkBAuhBDipvtbdRz3VEc0WD6r9iSras/TFivuVbUn2ljEfTWRFBgrr7q/rKws3njjDTSahr/eIj09nYCAACZPnkxQUBDHjx9nxowZnD9//qadjxBC3Gzyy3qEEEKYRZ6xkvW1aaiBnZo7aauyQlOt4lvjBT6tPc+bFl0b3c5oNPLKK6/Qrl07unbt2mCUe968eSbv7datG8XFxWRmZtKpU6dbeUpCCHHDZCRcCCGEWZw2FlOFEW9saauyAqCPygmA48bLTW63evVqDh8+zEcffYSVlVWj79m3bx9vvfUWISEhFBcX079/f/r373/Tz0EIIW4WGQkXQghxU6yqSSGZMgCOGC9STDUza04A4IcdLipLAOywULaxU9X9N5RL4+UoZ86cISwsjNdee42goKAmjx0XF8cXX3wBgLW1NXfffTdarfa/PykhhLhFJISL65KXl8e6des4ceIEarWaXr168fTTT+Pk5NTkNpMnT26wbOzYsUyfPh2AnTt3sm/fPjIyMjAajYSEhDTYJjIyku+//56cnBycnZ0ZM2YMEydONFm/bds2srKysLCwwNvbm0ceeUT5T7uwsJCvv/6akydPUlFRQefOnQkNDaVDhw4AxMfHs337dtLT0ykvL8fFxYW7776biRMnolKpKCsrY+3atSQlJXHx4kVsbGzo1q0bTzzxBK6uriZtzcnJYebMmVRWVtKhQweWLl0KQEJCgsnX5vX+7//+j4EDBzbrPGpra9m8eTN79+6luLgYT09PHnvsMfr06QPUfRW/Y8cO9uzZQ0FBAW3atOG+++5jzJgxJsfcs2cPu3fvJjs7GysrK/z8/HjrrbeU9enp6XzzzTecOXOGmpoa2rVrx7PPPkvXrnXlAr/99hs7duwgJycHe3t77r77bh566CHUavly7a9smzGLA8ZCk2Wf1KYAcJfKhddVAQCUUaOsLzVWA9COxke4d+3a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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "tensor([[0.3745]], device='cuda:0', grad_fn=<SigmoidBackward0>)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#num of features to use\n",
    "top_n = 10\n",
    "ind = np.random.choice(len(test))\n",
    "\n",
    "kan_model.plot_bars(test[ind][0].reshape(1, len(index_to_name)).to(device), test_data.iloc[0], top_n)\n",
    "kan_model.predict(test[ind][0].reshape(1, len(index_to_name)).to(device))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1ed58d30",
   "metadata": {},
   "source": [
    "# Interpretability Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "152f47a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''function to obtain feature scores from KAN model'''\n",
    "\n",
    "def get_local_values(example, index_to_name):\n",
    "    array_to_use = np.array(example)    \n",
    "    array = torch.FloatTensor(array_to_use).reshape(1, len(index_to_name))\n",
    "    local_importance = kan_model.get_local_importance(array.to(device))[-1]\n",
    "\n",
    "    names = []\n",
    "    values = []\n",
    "    for i, v in enumerate(local_importance):\n",
    "        name = index_to_name[i]\n",
    "        names.append(name)\n",
    "        values.append(v)\n",
    "    return names, values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "fe711de1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from data_preprocess import BlackBoxWrapper\n",
    "\n",
    "\n",
    "num_features = len(index_to_name)\n",
    "\n",
    "\n",
    "bb = BlackBoxWrapper(kan_model, num_features, device)\n",
    "\n",
    "def black_box(x, S):\n",
    "    pred = bb(x, S)\n",
    "    return pred.cpu().data.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c208c010",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cosine similarity: 0.9659984761853376 +- 0.02401544734843622,  Spearman rank: 0.92025729336334 +- 0.06396025962210482\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "import shapreg\n",
    "import pickle\n",
    "import os.path\n",
    "from numpy.linalg import norm\n",
    "from scipy.stats import spearmanr\n",
    "import copy\n",
    "\n",
    "all_cos_sim = []\n",
    "all_spearman_c = []\n",
    "all_krnl = []\n",
    "\n",
    "count = 1\n",
    "for x_, _ in tqdm(test_dataset):\n",
    "    _, kan_values = get_local_values(x_, index_to_name)\n",
    "\n",
    "    x = x_.reshape((1,x_.shape[0])).numpy()\n",
    "\n",
    "    # Run KernelSHAP to convergence\n",
    "    game_ = shapreg.games.PredictionGame(black_box, x)\n",
    "    try:\n",
    "        shap_values, all_results = shapreg.shapley.ShapleyRegression(\n",
    "            game_, batch_size=256, paired_sampling=True, detect_convergence=True,\n",
    "            bar=False, return_all=True)\n",
    "    except:\n",
    "        print('Singularity exception!')\n",
    "        continue\n",
    "\n",
    "    instance_l2_dis = []\n",
    "    instance_cos_sim = []\n",
    "    spearman_c = []\n",
    "\n",
    "    kan_values = np.array(kan_values)\n",
    "\n",
    "    knl_shp = shap_values.values.reshape(-1)\n",
    "    all_krnl.append(shap_values)\n",
    "\n",
    "    all_cos_sim.append(np.dot(kan_values, knl_shp)/(norm(kan_values)*norm(knl_shp)))\n",
    "    coef, p = spearmanr(kan_values, knl_shp)\n",
    "    all_spearman_c.append(coef)\n",
    "\n",
    "mean_cos_sim = np.mean(all_cos_sim)\n",
    "mean_spearman_c = np.mean(all_spearman_c)\n",
    "\n",
    "std_cos_sim = np.std(all_cos_sim)\n",
    "std_spearman_c = np.std(all_spearman_c)\n",
    "\n",
    "print('Cosine similarity: {} +- {},  Spearman rank: {} +- {}' .format(mean_cos_sim, std_cos_sim, \n",
    "                                                                      mean_spearman_c, std_spearman_c))\n",
    "\n",
    "with open(f'{data_name}/{data_name}_krnlshp_kan.pickle', 'wb') as file:\n",
    "    pickle.dump(all_krnl, file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e69ac62f",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
