{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "56557745",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from dgl import function as fn\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "from dataset import load_graph_dataset\n",
    "from tqdm import tqdm\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from train import train_preprocessed_data\n",
    "from model_edge_influence import EdgeInfluenceSGC\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a6fe20c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.005\n",
    "\n",
    "data_set_2 = 'pubmed'\n",
    "l2_term_2 = 0.004 # 0.001\n",
    "\n",
    "data_set_3 = 'citeseer'\n",
    "l2_term_3 = 0.003\n",
    "\n",
    "num_layer = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "202af984",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_cora = train_preprocessed_data(data_name = data_set_1, k = num_layer)\n",
    "train_x_cora, train_y_cora, test_x_cora, test_y_cora, val_x_cora, val_y_cora = loader_cora.load_graph_to_tabular()\n",
    "graph_cora, feat_cora, labels_cora, train_mask_cora, val_mask_cora, test_mask_cora, number_classes_cora = load_graph_dataset(data_set_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4ef2d6ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_pubmed = train_preprocessed_data(data_name = data_set_2, k = num_layer)\n",
    "train_x_pubmed, train_y_pubmed, test_x_pubmed, test_y_pubmed, val_x_pubmed, val_y_pubmed = loader_pubmed.load_graph_to_tabular()\n",
    "graph_pubmed, feat_pubmed, labels_pubmed, train_mask_pubmed, val_mask_pubmed, test_mask_pubmed, number_classes_pubmed = load_graph_dataset(data_set_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b29d5ade",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_citeseer = train_preprocessed_data(data_name = data_set_3, k = num_layer)\n",
    "train_x_citeseer, train_y_citeseer, test_x_citeseer, test_y_citeseer, val_x_citeseer, val_y_citeseer = loader_citeseer.load_graph_to_tabular()\n",
    "graph_citeseer, feat_citeseer, labels_citeseer, train_mask_citeseer, val_mask_citeseer, test_mask_citeseer, number_classes_citeseer = load_graph_dataset(data_set_3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9284423a",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl = pd.read_csv('result_data/cora_edge_influence_001.csv', header = None)\n",
    "cora_infl = cora_infl.loc[cora_infl[1] > 0]\n",
    "cora_infl = cora_infl.sort_values([1])\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "04610f01",
   "metadata": {},
   "outputs": [],
   "source": [
    "pubmed_infl = pd.read_csv('result_data/pubmed_edge_influence.csv', header = None)\n",
    "pubmed_infl = pubmed_infl.loc[pubmed_infl[0] > 0]\n",
    "pubmed_infl = pubmed_infl.sort_values([1])\n",
    "pubmed_infl.index = range(len(pubmed_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "d5e8950a",
   "metadata": {},
   "outputs": [],
   "source": [
    "citeseer_infl = pd.read_csv('result_data/citeseer_edge_influence.csv', header = None)\n",
    "citeseer_infl = citeseer_infl.loc[citeseer_infl[0] > 0]\n",
    "citeseer_infl = citeseer_infl.sort_values([1])\n",
    "citeseer_infl.index = range(len(citeseer_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7f4a1f96",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "i = 2\n",
    "\n",
    "acc_cora = []\n",
    "acc2_cora = []\n",
    "\n",
    "acc_pubmed = []\n",
    "acc2_pubmed = []\n",
    "\n",
    "acc_citeseer = []\n",
    "acc2_citeseer = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "67f22ec9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-1.125551</td>\n",
       "      <td>-5.463236</td>\n",
       "      <td>80.0</td>\n",
       "      <td>79.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-1.392733</td>\n",
       "      <td>-1.483720</td>\n",
       "      <td>1049.0</td>\n",
       "      <td>1049.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1.183323</td>\n",
       "      <td>-1.345793</td>\n",
       "      <td>554.0</td>\n",
       "      <td>554.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-0.889518</td>\n",
       "      <td>-1.342498</td>\n",
       "      <td>365.0</td>\n",
       "      <td>645.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-0.728295</td>\n",
       "      <td>-1.034265</td>\n",
       "      <td>2452.0</td>\n",
       "      <td>2079.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5588</th>\n",
       "      <td>-0.025072</td>\n",
       "      <td>-0.000009</td>\n",
       "      <td>2361.0</td>\n",
       "      <td>2361.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5589</th>\n",
       "      <td>-0.025072</td>\n",
       "      <td>-0.000009</td>\n",
       "      <td>1925.0</td>\n",
       "      <td>2361.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5590</th>\n",
       "      <td>-0.025072</td>\n",
       "      <td>-0.000009</td>\n",
       "      <td>2396.0</td>\n",
       "      <td>2361.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5591</th>\n",
       "      <td>-0.025072</td>\n",
       "      <td>-0.000009</td>\n",
       "      <td>2599.0</td>\n",
       "      <td>2361.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5592</th>\n",
       "      <td>0.006815</td>\n",
       "      <td>-0.000005</td>\n",
       "      <td>2032.0</td>\n",
       "      <td>2032.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5593 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0         1       2       3\n",
       "0    -1.125551 -5.463236    80.0    79.0\n",
       "1    -1.392733 -1.483720  1049.0  1049.0\n",
       "2    -1.183323 -1.345793   554.0   554.0\n",
       "3    -0.889518 -1.342498   365.0   645.0\n",
       "4    -0.728295 -1.034265  2452.0  2079.0\n",
       "...        ...       ...     ...     ...\n",
       "5588 -0.025072 -0.000009  2361.0  2361.0\n",
       "5589 -0.025072 -0.000009  1925.0  2361.0\n",
       "5590 -0.025072 -0.000009  2396.0  2361.0\n",
       "5591 -0.025072 -0.000009  2599.0  2361.0\n",
       "5592  0.006815 -0.000005  2032.0  2032.0\n",
       "\n",
       "[5593 rows x 4 columns]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2040158e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [00:40<00:00,  2.49it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_cora = cora_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_citeseer = citeseer_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_citeseer = citeseer_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "\n",
    "\n",
    "    nis_cora = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                           from_index=from_index_cora, to_index=to_index_cora)\n",
    "    nis_cora.remove_edges_sgc_from_influence()\n",
    "    feat_removed_cora = nis_cora.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_pubmed = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                           from_index=from_index_pubmed, to_index=to_index_pubmed)\n",
    "    nis_pubmed.remove_edges_sgc_from_influence()\n",
    "    feat_removed_pubmed = nis_pubmed.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_citeseer = EdgeInfluenceSGC(graph = graph_citeseer, feature=feat_citeseer, \n",
    "                           from_index=from_index_citeseer, to_index=to_index_citeseer)\n",
    "    nis_citeseer.remove_edges_sgc_from_influence()\n",
    "    feat_removed_citeseer = nis_citeseer.calculate_modified_features()\n",
    "\n",
    "    \n",
    "    lr_cora = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    train_x_cora = feat_removed_cora[train_mask_cora == 1].numpy()\n",
    "    lr_cora.fit(train_x_cora, train_y_cora, sample_weight=None, verbose=False)\n",
    "    acc_cora.append(np.mean(lr_cora.model.predict(test_x_cora) == test_y_cora))\n",
    "    acc2_cora.append(np.mean(lr_cora.model.predict(val_x_cora) == val_y_cora))\n",
    "\n",
    "\n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_2, fit_intercept=True)\n",
    "    train_x_pubmed = feat_removed_pubmed[train_mask_pubmed == 1].numpy()\n",
    "    lr_pubmed.fit(train_x_pubmed, train_y_pubmed, sample_weight=None, verbose=False)\n",
    "    acc_pubmed.append(np.mean(lr_pubmed.model.predict(test_x_pubmed) == test_y_pubmed))\n",
    "    acc2_pubmed.append(np.mean(lr_pubmed.model.predict(val_x_pubmed) == val_y_pubmed))\n",
    "\n",
    "\n",
    "    lr_citeseer = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_3, fit_intercept=True)\n",
    "    train_x_citeseer = feat_removed_citeseer[train_mask_citeseer == 1].numpy()\n",
    "    lr_citeseer.fit(train_x_citeseer, train_y_citeseer, sample_weight=None, verbose=False)\n",
    "    acc_citeseer.append(np.mean(lr_citeseer.model.predict(test_x_citeseer) == test_y_citeseer))\n",
    "    acc2_citeseer.append(np.mean(lr_citeseer.model.predict(val_x_citeseer) == val_y_citeseer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fa9a2c70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_cora[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.78, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "e1f75c80",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.812\n",
      "0.0\n",
      "\n"
     ]
    }
   ],
   "source": [
    "index_cora = np.where(acc2_cora == max(acc2_cora))\n",
    "print(np.array(acc_cora)[index_cora].mean())\n",
    "print(np.array(acc_cora)[index_cora].std())\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "57b948ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEWCAYAAAB8LwAVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABEKUlEQVR4nO3dd3hUZdrH8e8NBEIJoUoLCFKlhiYKKlUEBJEVRUUFVkVEVFx1EdfC2tZXUVkbiq6giBRRUAEVQZqiSDFSBUKTUKSX0JPc7x9nJkwmJ8kkZDIp9+e65mLmtHlOEuY3TznPEVXFGGOM8Vco1AUwxhiTO1lAGGOMcWUBYYwxxpUFhDHGGFcWEMYYY1xZQBhjjHFlAWHMBRCRCSLyfEF7b1MwWEAYY4xxZQFhjDHGlQWEMYCIbBeRkSKyXkQOi8h4EQkXkYEi8qPftioidXwWVRCR70XkuIgsEpGL/bYdKiKbPeufE5HaIvKziBwTkWkiUtRn+54iEiMiR0RkqYg09VnXXERWeY4zFQgP5s/EGAsIY87rD1wL1AbqAU9mYr/ngApADDDJb303oCVwOfBPYJxnn+pAY+BWABFpAXwI3AuUB94DvhKRYp4QmQlMBMoBnwE3Zv4UjQmcBYQx572lqjtV9RDwAp4P7gDMVtXFqnoG+BdwhYhU91n/f6p6TFXXAWuBuaq6VVWPAt8AzT3b3QO8p6rLVDVRVT8CzuAEy+VAGDBGVc+p6nRg+YWesDHpsYAw5rydPs93AFUzu5+qxgOH/Pb9y+f5KZfXpTzPLwYe8TQvHRGRIzi1jKqexy5NObvmjgDLZ0yWWEAYc57vt/4awG7gBFDCu1BEKqe3n4iUwmkC2p2F998JvKCqZXweJVR1MrAHqCYi4ldGY4LGAsKY8+4XkSgRKQc8AUwFfgcaiUi0iIQDo1z26yEiV3r6CZ4DlqnqTpftMvI+MERE2oijpIhcJyIRwM9AAvCgiBQRkb8Bl2XhPYwJmAWEMed9CswFtnoez6vqJuBZYB6wGfgxjf2ewWlaaonTAZ1pqroCpx/iLeAwEAsM9Kw7C/zN8/ow0A/4IivvY0ygxG4YZIwzzBW4W1XnhbosxuQWVoMwxhjjKqgBISLdRGSjiMSKyOMu6yNF5GsR+V1E1onIIJ9120VkjeeioRXBLKcxxpjUgtbEJCKFgU3ANUAczpjtW1V1vc82TwCRqjpCRCoCG4HKqnrWU+VvpaoHglJAY4wx6QpmDeIyINZzQdBZYArQ228bBSI8Q/dK4XTyJQSxTMYYYwJUJIjHrkbKC4/igDZ+27wFfIUzZjwC6KeqSZ51CswVEcW5unSc25uIyGBgMEDJkiVbNmjQIPvOwBhj8rmVK1ceUNWKbuuCGRDissy/PetanLlrOuHMf/O9iCxR1WNAO1XdLSIXeZb/oaqLUx3QCY5xAK1atdIVK6y7whhjAiUiaV6RH8wmpjhSXpkaReqrSwcBX6gjFtgGNABQ1d2ef/cBM7CLgowxJkcFMyCWA3VFpJbnCtNbcJqTfP0JdAYQkUpAfWCr5wrSCM/ykkBXnEnOjDHG5JCgNTGpaoKIDAO+AwoDH6rqOhEZ4ln/Ls60BBNEZA1Ok9QIVT0gIpcAMzzTzhQBPlXVb4NVVmOMManlqyup3fogzp07R1xcHKdPnw5RqYyb8PBwoqKiCAsLC3VRjCnQRGSlqrZyWxfMTupcIS4ujoiICGrWrEnKiTBNqKgqBw8eJC4ujlq1aoW6OMaYNOT7qTZOnz5N+fLlLRxyERGhfPnyVqszJpfL9wEBWDjkQvY7MSb3KxABYYwxJvMsIILsyJEjvPPOO1nef8yYMZw8eTIbS2SMMYGxgAiy/BAQCQk2PZYxBZEFRJA9/vjjbNmyhejoaB577DEAXnnlFVq3bk3Tpk155plnADhx4gTXXXcdzZo1o3HjxkydOpU33niD3bt307FjRzp27Jjq2M8++yytW7emcePGDB48GO+Q5djYWLp06UKzZs1o0aIFW7ZsAeDll1+mSZMmNGvWjMcfd2Zf79ChA96hwQcOHKBmzZoATJgwgZtuuolevXrRtWtX4uPj6dy5My1atKBJkyZ8+eWXyeX4+OOPadq0Kc2aNeOOO+7g+PHj1KpVi3PnzgFw7NgxatasmfzaGJM35Pthrr7+/fU61u8+lq3HbFi1NM/0apTm+pdeeom1a9cSExMDwNy5c9m8eTO//vorqsr111/P4sWL2b9/P1WrVmX27NkAHD16lMjISF577TUWLFhAhQoVUh172LBhPP300wDccccdzJo1i169etG/f38ef/xx+vTpw+nTp0lKSuKbb75h5syZLFu2jBIlSnDo0KEMz+3nn39m9erVlCtXjoSEBGbMmEHp0qU5cOAAl19+Oddffz3r16/nhRde4KeffqJChQocOnSIiIgIOnTowOzZs7nhhhuYMmUKN954o13zYEweYzWIHDZ37lzmzp1L8+bNadGiBX/88QebN2+mSZMmzJs3jxEjRrBkyRIiIyMzPNaCBQto06YNTZo04YcffmDdunUcP36cXbt20adPH8C5IK1EiRLMmzePQYMGUaJECQDKlSuX4fGvueaa5O1UlSeeeIKmTZvSpUsXdu3axV9//cUPP/xA3759kwPMu/3dd9/N+PHjARg/fjyDBg1yfxNjTK5VoGoQ6X3TzymqysiRI7n33ntTrVu5ciVz5sxh5MiRdO3aNbl24Ob06dMMHTqUFStWUL16dUaNGsXp06dJ68p4VXUdWlqkSBGSkpKSj+mrZMmSyc8nTZrE/v37WblyJWFhYdSsWTP5/dyO265dO7Zv386iRYtITEykcePGaZ6LMSZ3shpEkEVERHD8+PHk19deey0ffvgh8fHxAOzatYt9+/axe/duSpQowe23386jjz7KqlWrXPf38n6YV6hQgfj4eKZPnw5A6dKliYqKYubMmQCcOXOGkydP0rVrVz788MPkDm9vE1PNmjVZuXIlQPIx3Bw9epSLLrqIsLAwFixYwI4dzgzBnTt3Ztq0aRw8eDDFcQHuvPNObr31Vqs9GJNHFagaRCiUL1+edu3a0bhxY7p3784rr7zChg0buOKKKwAoVaoUn3zyCbGxsTz22GMUKlSIsLAwxo4dC8DgwYPp3r07VapUYcGCBcnHLVOmDPfccw9NmjShZs2atG7dOnndxIkTuffee3n66acJCwvjs88+o1u3bsTExNCqVSuKFi1Kjx49ePHFF3n00Ue5+eabmThxIp06dUrzPPr370+vXr1o1aoV0dHReG/M1KhRI/71r3/Rvn17ChcuTPPmzZkwYULyPk8++SS33nprdv9YjTE5IN9P1rdhwwYuvfTSEJWoYJs+fTpffvklEydOdF1vvxtjQq9AT9ZnQuOBBx7gm2++Yc6cOaEuijEmiywgTFC8+eaboS6CMeYCWSe1McYYVxYQxhhjXFlAGGOMcWUBYYwxxpUFhDHGGFcWELlMqVKlQl0EY4wBLCBMGuweEMaYoF4HISLdgP8ChYEPVPUlv/WRwCdADU9ZRqvqeJ/1hYEVwC5V7XnBBfrmcdi75oIPk0LlJtD9pTRXjxgxgosvvpihQ4cCMGrUKESExYsXc/jwYc6dO8fzzz9P7969M3yr+Ph4evfu7brfxx9/zOjRoxERmjZtysSJE/nrr78YMmQIW7duBWDs2LFUrVqVnj17snbtWgBGjx5NfHw8o0aNokOHDrRt25affvqJ66+/nnr16vH8889z9uxZypcvz6RJk6hUqRLx8fE88MADrFixAhHhmWee4ciRI6xdu5bXX38dgPfff58NGzbw2muvXdCP1xgTOkELCM+H+9vANUAcsFxEvlLV9T6b3Q+sV9VeIlIR2Cgik1T1rGf9Q8AGoHSwyhlst9xyC8OHD08OiGnTpvHtt9/y8MMPp7q3gtusqL7Cw8MDvicDwIMPPkj79u2ZMWMGiYmJxMfHc/jw4XTf48iRIyxatAiAw4cP88svvyAifPDBB7z88su8+uqrPPfcc0RGRrJmzZrk7YoWLUrTpk15+eWXCQsLY/z48bz33nsX+uMzxoRQMGsQlwGxqroVQESmAL0B34BQIEKcT8ZSwCEgwbN9FHAd8ALwj2wpUTrf9IOlefPmybO17t+/n7Jly1KlShUefvhhFi9eTKFChZLvrVC5cuV0j+W9J4P/fmndk+GHH37g448/BqBw4cJERkZmGBD9+vVLfh4XF0e/fv3Ys2cPZ8+epVatWgDMmzePKVOmJG9XtmxZADp16sSsWbO49NJLOXfuHE2aNMnkT8sYk5sEMyCqATt9XscBbfy2eQv4CtgNRAD9VDXJs24M8E/P8jSJyGBgMECNGjUuuNDB0LdvX6ZPn87evXu55ZZb0ry3QkYye08GN773f4D07wHxwAMP8I9//IPrr7+ehQsXMmrUKCDte0vcfffdvPjiizRo0MCm+DYmHwhmJ7XbJ5b/1LHXAjFAVSAaeEtESotIT2Cfqq7M6E1UdZyqtlLVVhUrVrzAIgfHLbfcwpQpU5g+fTp9+/ZN894KGcnsPRk6d+6cPG14YmIix44do1KlSuzbt4+DBw9y5swZZs2ale77VatWDYCPPvooeXnXrl156623kl97ayVt2rRh586dfPrppzbFtzH5QDADIg6o7vM6Cqem4GsQ8IU6YoFtQAOgHXC9iGwHpgCdROSTIJY1qBo1asTx48epVq0aVapUoX///qxYsYJWrVoxadKk5HsrZCSt/XzvydCsWTP+8Q+nRe6///0vCxYsoEmTJrRs2ZJ169YRFhbG008/TZs2bejZs2e67z1q1ChuuukmrrrqqhT3xH7yySc5fPgwjRs3plmzZinuU3HzzTfTrl275GYnY0zeFbT7QYhIEWAT0BnYBSwHblPVdT7bjAX+UtVRIlIJWAU0U9UDPtt0AB4NZBST3Q8i9Hr27MnDDz9M586dM9zWfjfGhF5694MIWg1CVROAYcB3OCORpqnqOhEZIiJDPJs9B7QVkTXAfGCEbziYvOPIkSPUq1eP4sWLBxQOxpjcL6jXQajqHGCO37J3fZ7vBrpmcIyFwMIgFC/XWrNmDXfccUeKZcWKFWPZsmUhKlHGypQpw6ZNm0JdDGNMNrIbBuVCTZo0ISYmJtTFMMYUcDbVhjHGGFcWEMYYY1xZQBhjjHFlAZEDXnjhBRo1akTTpk2Jjo5m2bJlJCQk8MQTT1C3bl2io6OJjo7mhRdeSN7He9V17dq1adiwIT169LBOYGNMjrJO6iD7+eefmTVrFqtWraJYsWIcOHCAs2fP8uSTT7J3717WrFlDeHg4x48f59VXXwWcqSz69OnDgAEDkuc8iomJ4a+//qJevXqhPB1jTAFiARFke/bsoUKFChQrVgyAChUqcPLkSd5//322b99OeHg4ABEREclzHS1YsICwsDCGDBmSfJzo6OicLroxpoArcAHRYUKHVMtubnQzQ1sP5eS5k/SY1CPV+oHRAxkYPZADJw/Qd1rfFOsWDlyY7vt17dqVZ599lnr16tGlSxf69etH2bJlqVGjBhER7vMQrl27lpYtWwZ8TsYYEwzWBxFkpUqVYuXKlYwbN46KFSvSr18/Fi5cmGKb8ePHEx0dTfXq1dm5c6f7gYwxJocFbS6mUMgLczFNnz6d9957j1WrVrF9+/YUtYjGjRsza9YstmzZwr///W8WL14cwpIGX2773RhTEIVkLibj2LhxI5s3b05+HRMTQ/369bnrrrsYNmxY8v0YEhMTOXvWuZFep06dOHPmDO+//37yfsuXL0++05sxxuSEAtcHkdO8928+cuQIRYoUoU6dOowbN47IyEieeuopGjduTEREBMWLF2fAgAFUrVoVEWHGjBkMHz6cl156ifDwcGrWrMmYMWNCfTrGmALEmphMyNjvxpjQsyYmY4wxmWYBYYwxxpUFhDHGGFcWEMYYY1xZQBhjjHFlAWGMMcaVBUQuMmbMGE6ePBnqYhhjDGABkatYQBhjchMLiCA7ceIE1113Hc2aNaNx48ZMnTqV+fPn07x5c5o0acLf//53zpw5wxtvvMHu3bvp2LEjHTt2BOC+++6jVatWNGrUiGeeeSbEZ2KMKWiCOtWGiHQD/gsUBj5Q1Zf81kcCnwA1PGUZrarjRSQcWAwU8yyfrqrZ8wnZoUPqZTffDEOHwsmT0CP1dN8MHOg8DhyAvimn+8ZvZlZ/3377LVWrVmX27NkAHD16lMaNGzN//nzq1avHnXfeydixYxk+fDivvfYaCxYsoEKFCoBzJ7py5cqRmJhI586dWb16NU2bNs30KRtjTFYErQYhIoWBt4HuQEPgVhFp6LfZ/cB6VW0GdABeFZGiwBmgk2d5NNBNRC4PVlmDqUmTJsybN48RI0awZMkStm/fTq1atZLvDDdgwIA0Z22dNm0aLVq0oHnz5qxbt47169fnZNGNMQVcMGsQlwGxqroVQESmAL0B3085BSJERIBSwCEgQZ0JouI924R5HtkzaVR63/hLlEh/fYUKGdYY/NWrV4+VK1cyZ84cRo4cSdeuXQPab9u2bYwePZrly5dTtmxZBg4cmDzzqzHG5IRg9kFUA3zvfhPnWebrLeBSYDewBnhIVZPAqYGISAywD/heVZe5vYmIDBaRFSKyYv/+/dl8Chdu9+7dlChRgttvv51HH32UpUuXsn37dmJjYwGYOHEi7du3B5zbjh4/fhyAY8eOUbJkSSIjI/nrr7/45ptvQnYOxpiCKZg1CHFZ5l8LuBaIAToBtYHvRWSJqh5T1UQgWkTKADNEpLGqrk11QNVxwDhwZnPNxvJnizVr1vDYY49RqFAhwsLCGDt2LEePHuWmm24iISGB1q1bJ997evDgwXTv3p0qVaqwYMECmjdvTqNGjbjkkkto165diM/EGFPQBG26bxG5Ahilqtd6Xo8EUNX/+GwzG3hJVZd4Xv8APK6qv/od6xnghKqOTu89bbrvvMV+N8aEXqim+14O1BWRWp6O51uAr/y2+RPo7ClkJaA+sFVEKnpqDohIcaAL8EcQy2qMMcZP0JqYVDVBRIYB3+EMc/1QVdeJyBDP+neB54AJIrIGp0lqhKoeEJGmwEeekVCFgGmqOitYZTXGGJNaUK+DUNU5wBy/Ze/6PN8NpBrWo6qrgebZWA6cgVImt8hPdzI0Jr/K91dSh4eHc/DgQftAykVUlYMHDxIeHh7qohhj0hHUGkRuEBUVRVxcHLlxCGxBFh4eTlRUVKiLYYxJR74PiLCwMGrVqhXqYhhjTJ6T75uYjDHGZI0FhDHGGFcWEMYYY1xZQBhjjHFlAWGMMcaVBYQxxhhXFhDGGGNcWUAYY4xxZQFhjDHGlQWEMcYYVxYQxhhjXFlAGGOMcWUBYYwxxpUFhDHGGFcWEMYYY1xZQBhjjHFlAWGMMcaVBYQxxhhXAQWEiHwuIteJiAWKMcYUEIF+4I8FbgM2i8hLItIgkJ1EpJuIbBSRWBF53GV9pIh8LSK/i8g6ERnkWV5dRBaIyAbP8ocCPiNjjDHZIqCAUNV5qtofaAFsB74XkaUiMkhEwtz2EZHCwNtAd6AhcKuINPTb7H5gvao2AzoAr4pIUSABeERVLwUuB+532dcYY0wQBdxkJCLlgYHA3cBvwH9xAuP7NHa5DIhV1a2qehaYAvT220aBCBERoBRwCEhQ1T2qugpAVY8DG4BqgZbVGGPMhSsSyEYi8gXQAJgI9FLVPZ5VU0VkRRq7VQN2+ryOA9r4bfMW8BWwG4gA+qlqkt971wSaA8sCKasxxpjsEVBAAG+p6g9uK1S1VRr7iNvmfq+vBWKATkBtnKarJap6DEBESgGfA8O9y1K9ichgYDBAjRo1MjgNY4wxgQq0ielSESnjfSEiZUVkaAb7xAHVfV5H4dQUfA0CvlBHLLANp6aCp2/jc2CSqn6R1puo6jhVbaWqrSpWrBjg6RhjjMlIoAFxj6oe8b5Q1cPAPRnssxyoKyK1PB3Pt+A0J/n6E+gMICKVgPrAVk+fxP+ADar6WoBlNMYYk40CDYhCng9tIHmEUtH0dlDVBGAY8B1OJ/M0VV0nIkNEZIhns+eAtiKyBpgPjFDVA0A74A6gk4jEeB49MnVmxhhjLkigfRDfAdNE5F2cfoQhwLcZ7aSqc4A5fsve9Xm+G+jqst+PuPdhGGOMySGBBsQI4F7gPpwP7rnAB8EqlDHGmNALKCA8Q0/Heh7GGGMKgECvg6gL/Afniuhw73JVvSRI5TLGGBNigXZSj8epPSQAHYGPcS6aM8YYk08FGhDFVXU+IKq6Q1VH4VzcZowxJp8KtJP6tGeq780iMgzYBVwUvGIZY4wJtUBrEMOBEsCDQEvgdmBAkMpkjDEmF8iwBuG5KO5mVX0MiMeZHsMYY0w+l2ENQlUTgZa+V1IbY4zJ/wLtg/gN+FJEPgNOeBemN4meMcaYvC3QgCgHHCTlyCUFLCCMMSafCvRKaut3MMaYAibQK6nHk/pmP6jq37O9RMYYY3KFQJuYZvk8Dwf6kPrmP8YYY/KRQJuYPvd9LSKTgXlBKZExxphcIdAL5fzVBewG0MYYk48F2gdxnJR9EHtx7hFhjDEmnwq0iSki2AUxxhiTuwTUxCQifUQk0ud1GRG5IWilMsYYE3KB9kE8o6pHvS9U9QjwTFBKZIwxJlcINCDctgt0iKwxxpg8KNCAWCEir4lIbRG5REReB1YGs2DGGGNCK9CAeAA4C0wFpgGngPsz2klEuonIRhGJFZHHXdZHisjXIvK7iKwTkUE+6z4UkX0isjbAMhpjjMlGgY5iOgGk+oBPj+c+Em8D1wBxwHIR+UpV1/tsdj+wXlV7iUhFYKOITFLVs8AE4C2c+18bY4zJYYGOYvpeRMr4vC4rIt9lsNtlQKyqbvV84E8Bevtto0CE514TpYBDQAKAqi72vDYXKuEMaKqptEx2OH00+D/bsyeDe3xj0hBoE1MFz8glAFT1MBnfk7oasNPndZxnma+3gEtx5nVaAzykqkkBlskEYvP38NLFsHpqqEuS/xzcAqPrwfIPgvceS9+El6rDlh+C9x7GpCHQgEgSkeSpNUSkJi6zu/pxuwOd/z7XAjFAVSAaeEtESgdYJm9ZBovIChFZsX///szsmv9t/h6m3AYJpyB2fqhLk/8sHg0Jp2HxK3DuVPYff+mbMPdJSEqEH563WqDJcYEGxL+AH0VkoohMBBYBIzPYJw6o7vM6itQzwA4CvlBHLLANaBBgmQBQ1XGq2kpVW1WsWDEzu+Zv3nC46FK4+ErYExPqEuUvB7c4tbKLr4T4v2DF+Ow9vjccGt4A142GXSsh1ubHNDkroIBQ1W+BVsBGnJFMj+CMZErPcqCuiNQSkaLALcBXftv8CXQGEJFKQH1ga8ClN+58w+GOmVDrKjiwGc4cD3XJ8o/Fo6FwUej7IdS6Gn4ak321CN9wuPF/0PxOiKwBC/9jtQiTowLtpL4bmI8TDI8AE4FR6e2jqgnAMOA7YAMwTVXXicgQERni2ew5oK2IrPEcf4SqHvC852TgZ6C+iMSJyF2ZPbkCyT8cSpSDKtGAwt41IS5cPuGtPbS+CyIqQfvHs68W4R8OhYtAkaJw9SNWizA5LtAmpoeA1sAOVe0INAcybPBX1TmqWk9Va6vqC55l76rqu57nu1W1q6o2UdXGqvqJz763qmoVVQ1T1ShV/V+mzy5Qqs5In7zOLRwAqkY7/+7+LVQly1+8tYe2Dzqva7bLnlqEWzh4NbvNahEmxwU6XcZpVT0tIohIMVX9Q0TqB7VkOeXsCRjbFlrcCVc9EurSZN2e1e7hABBRGSKqwO6YUJUub/h9Cqz40Gk2ioxy38Zbe7j8Pqf24NX+cZjQw6lFXDHUfd/EBJjzCKz/MvU6VTh9xD0c4Hwt4uuHnFpE3WuycobGZEqgARHnuQ5iJvC9iBwmv9xytGhJKFkR1s3I2wGx4EUIK5E6HLyqRFtHdXrOnnS+vZ/YDxOug4Gz3UPCv/bg5VuLaDUIwoqnXJ+YADOHwJrPoPGNUKJ86mOXrgpXPJA6HLya3QaLX3VqEXW6gLgNFDQm+wR6JXUfz9NRIrIAiAS+DVqpclqjPvDdE863w/K1Q12azNv9G2z6Bjo+6R4O4DQzbfrW6aguZrf3SGXFh044XPsiLHzJPSTSqj14pVWL8A2Hzs/AVf/IWhmtFmFyWKZvOaqqi1T1K8/V0flDQ88F3utnhrQYWbbw/yC8DLQZnPY21lGdtrMnnW/+tdrDFffDHTPg5CEnJI7Gnd8urdqDl1tfRHaFg5f1RZgclNV7UucvkVEQ1dppZsprvLWHK4ZBeGTa2yV3VMfkRKnyFm/toYNnurGoVqlDwn/kUlp8RzRldziAjWgyOcoCwqtRH+fb9cEtoS5J5gRSewCfjmobyZSCb+3h4rbnl/uHxHdPpF978PLWIn58HWYMzt5w8LJahMkhFhBeebGZKdDag5d1VKfmX3vw5RsSm77NuPbg1f5xOLEP1n6e/eEAfrUIm0LFBI8FhFdebGYKtPbgVTXarqj2lVbtwVdUK2dkWKO/QbvhgR23Zjto9xD0GJ394eDV7DYoFgkb/CcnMCb7WED4ykvNTJmtPYB1VPtLr/bgK6ol3DQeSmVirq9rnoXL7rmw8qWnSFEn1Lb/GLz3MAWeBYSvvNTMlNnaA1hHta9Aag+5Xc0r4dAWOJY/LkkyuY8FhK+80syUldoDnO+otn6IwGsPuVnNK51/t/8U2nKYfMsCwl9eaGbKSu3Bq0q0jWTKD7UHgMpNnH6I7UtCXRKTTwU61UbB0bC3M6Rx/cy0p944EOuMUHG7+V3xMtByEISFB6d8u1aev2o6M7UHrwu5ovrYbmfUTPRtUKhw5t/b17bFULQUVGtxYcdJSoRfx8GpI4Hvc2Bj3q89gPM7yI5+iPj9sHICJCWkXhdW3JmnLK0r9AO1f6NTM3cbllu8rDM9SZFiF/YeO5dD0rm8HfqqzvU2NS6HsjVDXRoLiFR8m5ncAmLvWvj4ejh5MO1jxM6Hfp9kf0gciIUp/aHkRVmrPUDKjurM/Ec6stO5HuDIDucD6YZ3sh4Sv0+FGfdCqUrw0O8X9nNa8xl8m4UP+vrX5e0PEq+aVzpfGI7tduZyyor5o+C3T9Jev/ZzuPPLrIfEnt/ho+udyQjTsnUh3PxR1kNi47cw9XYn0IavdkInr1GFOY/B8vehVGVnqpcKdUJaJAsIN2nNzeQNh8LF4IFV7vM2rfwIvn7Q+WPNzpA4EAsf9YTEszBgVtZqD5CyozrQD0hvOJw6Aq3+7rTfQ9ZCwhsOF10K+9bDqo+gzb2ZO4ZXYgIsetlparl3ScGcvM63H6LpTZnf/9A2iJkMbe6D7i+lXr95njNL8Me9sxYS3nAoFgGDF0K5Wqm3Wf4BzH4Epg3IWkh4w6F8bdj/B/wyFjo+kbljhJpvODS/3Tkn73xgIQwJ64Nw4zaayTccBs5Ke1K/lgOg1xsQ+73zR3vu9IWXxz8cKjXM+rEy21HtGw53zoCerzvNW6unwMyhThNPoLzhUPNKuHs+1LwKlryW9Z/R2unOKJ72jxfMcIAL74dYMhoKh8GVw93X1+0Ct3zqNBF93Nu5aDBQvuEw4Gv3cABofTdc96pTE5o2IHP3ZvGGQ+XG8Pfv4NLrnYA4dTjwY4Sabzi0fQCuf8v5jElKcP7vHYgNWdEsINz4j2YKNBy8sjMksjMcvKpEBzbU1T8cqrV0lrd/LPMh4RsOt02DoiWg/QiI3+vUIjLLt/bQ4LrM759fXEg/hLf20HKQ88UhLVkJiUDDwSsrIeEbDnfMdPr/2o+AM8eckMgL/MPhmuecLzsXXZorQsICIi3e0Uwbvs5cOHhlR0gEIxzAc0X1pvSvqE4rHLwyExJu4QDOvbKzWouw2sN5Wb0eIqPag6/MhERmw8ErMyHhFg7gvM4rtYi0wsErF4SE9UGkxTuaaertEFE1c+Hg1XKA8+/XD8LU/nBZJtraE07DN//M/nCAjDuqMwoHr/aPOf8ueB40EZrcnHqbA5ucG/H4h0PyMUY4IZiZvgirPaSUlX4Ib+3hssHp1x58eUPC2yfR6UnAL5zPHHP6EzIbDl6t73b+nf0ITLsTWrnciv7oTvhmROpw8Go/wpmCJCf7Ik4egrgVmdtn42xn9JhbOHh5Q2JCz5D0SVhApCUyyvl2e3BL1sLByzckMjs9c4ny2R8OkH5HdaDh4OUbEms+c9+m5lXu4QApaxEtBgTWqe+tPfSbZLUHSNkPEWhAZKb24Ms3JD51+UIAEFk9a+Hg5RsSm9K4L1nV5u7hAClrEZffF/wRTYd3OB/gR//M/L7phYNXCENCNB9NF9yqVStdsSKTKZ6eM8dBCrt/sGXWoW2Z6+AD5z/YhY4/T8urDZxpqf827vyyzIaDrwOb4fSx1MsLFYJKTdK+jSbAtiVOLaL7yxnXIhIT4O3LnN9JQR255ObTW5za2oOrMt720DZ4s6VTe3AbuRSIY7vh2B73dRXrZc9dCw9thZMuzUQCVGqc/minvWvh3XZObSKYtQhvOJw5Bn3ec25fHKiiJaFi/cD/hvdtcN6rUJFsDQkRWamqrdzWWQ0iPdl5a85ytbL+jSoY/DuqLyQcACrUzXpZMlOLsNqDu8xcD5HV2oOv0lWzft1FoMpdAln9fpQTtQjfcLjzy/M182AJQU3COqkLquSO6vgLD4fsEMiIJut7SFug8zIFOnIpPwjmiKacDgevHO64DmpAiEg3EdkoIrEikupyVxGJFJGvReR3EVknIoMC3ddcIG9H9cY5oQ8HCGxEk41cSlug10NkR+0hrwjWiKZQhYNXDoZE0AJCRAoDbwPdgYbArSLi39t6P7BeVZsBHYBXRaRogPuaC+H9o55xb+jDwctbi/h1nNNf4/s4ccBqD+kJ5HqIglR78PLWIn76b+q/qaw89v0R2nDwyqGQCGYfxGVArKpuBRCRKUBvYL3PNgpEiIgApYBDQALQJoB9zYWIqAylo5yO+NwQDnC+FvH9U87DjfU9pC29fohzp2HW8IJTe/Dy1iJ+fN15ZIfwMqENBy/fPomPesGwX7O335TgBkQ1YKfP6zicD35fbwFfAbuBCKCfqiaJSCD7AiAig4HBADVq1MiekhcUt011RgOVuyTUJTnvhneci6BIY9ZPqz2kLa3rIc6ddoalbl0Evd8uOLUHrx6jnRF7brMvZ0WdLlkf9p7dvCGxa1W2hwMENyDcvub5/6+/FogBOgG1ge9FZEmA+zoLVccB48AZ5prVwhZIlRuHugSplamR9ZlqCzq36yG84bDlB7j+TWjeP7RlDIWISsG9/WuoXXSp8wiCYAZEHFDd53UUTk3B1yDgJXUuxogVkW1AgwD3TW3jRujQIeWym2+GoUPh5Eno0SP1PgMHOo8DB6Bv39Tr77sP+vWDnTvhjjtSr3/kEejVy3nve13G8D/5JHTpAjExMHx46vUvvght28LSpfCEy3jtMWMgOhrmzYPnn0+9/r33oH59+PprePXV1OsnToTq1WHqVBjrMppj+nSoUAEmTHAe/ubMgRIl4J13YNq01OsXLnT+HT0aZs1Kua54cfjmG+f5c8/B/Pkp15cvD59/7jwfORJ+/jnl+qgo+MQzDfXw4c7P0Fe9ejDOcx3H4MGwaVPK9dHRzs8P4PbbIS4u5forroD//Md5fuONcNBvCvfOneEpT1NX9+5w6lTK9T17wqOPOs/9/+4gNH97+07DufHw2mp4/J+w/wP46XtYEQUL/wf87/z+9rfnPC/of3vpCOYopuVAXRGpJSJFgVtwmpN8/Ql0BhCRSkB9YGuA+xpj/IVHwrlTzlQtC150ag7tRzj33jAmk4J6JbWI9ADGAIWBD1X1BREZAqCq74pIVWACUAWnWeklVf0krX0zer9sv5LamLxmdwyMa+/MH3Z8j9Os1MKl9mGMR3pXUttUG8bkJ0mJ8H+1nGGYFg4mADbVhjEFRaHC0Ot1KFIcGri0PRuTCRYQxuQ3jW8MdQlMPmFzMaVj0rIdjPpqHXGHT4a6KMYYk+OsBpGGpCTltbmbOHjiLJOW7aBvy+rc37E2UWWzYepvY4zJAywg0rBm11EOnjjLyO4N2HXkFFN+3cn0lTstKIwxBYYFRBoWbtyPCNzUqjrlShblvg61GbtwS3JQ3H3VJYzo1iDUxTTGmKCxPog0LNy0j2ZRZShXsigAVSKL82zvxix8rAPXNKzE2IVb2HHwRIhLaYwxwWMB4eLQibPE7DxCh/qpbx9YtUxx/nWdM/P47DVp3HLRGGPyAQsIF0s270cVOtS/yHV9tTLFaV6jDLNXBycgEpOUWat389mKnZxJSAzKexhjTEasD8LFwo37KVeyKE2rRaa5zXVNqvD87A3sOHiCi8uXzJb39QbDf+dvZut+p/nq1bmbuL9jbW5uXZ1iRQpny/sYY0wgrAbhJylJWbxpP1fXrUChQmnfmKZ7kypA9jQzJSYpX8bs4prXF/HQlBiKFi7E2P4t+OSuNkSVLc5TX66j/csLmfjzdqtRGGNyjNUg/HiHt3Zs4N685OXbzDS0Q50sv98Pf/zF87M3sHX/CRpUjmBs/xZc26hycji1q1OepVsO8vr3m3jqy3W8vWCL1SiMMTnCahB+vMNbr6qbuoPa33VNqrBu97Esj2Y6cvIs932yCgHG9m/BnAevonuTKilqLiJCuzoV+GzIFVajMMbkKAsIP/7DW9Nzoc1MX6zaxZmEJN68tUWqYPAnIlxZ14LCGJNzLCB8pDe81c2FjGZSVSb/+ifR1cvQsGrpgPdLLyg++WUH+Wn6dmNMaFlA+MhoeKubrDYzrdhxmM374rntshqZLSaQMigm3e0ExZMz1zLjt11ZOp4xxvizgPARyPBWf1ltZpq87E8iihWhZ7MqmdrPn28fRcMqpXnzh1gSEpMu6JjGGAMWEMkCHd7qLyvNTEdOnmXWmj3c0LwaJYpmz0AyEeGhLnXZduAEX/2+O1uOaYwp2CwgPLzDWzPTvOSV2WamL1bt4mxCErdmsXkpLV0bVrJahDEm21hAeHiHt15dL7AOal+ZaWbKaud0IKwWYYzJThYQHpkZ3uovM81MF9o5nZHM1CJOn0vkXD6oaZw+l7khvklJytmEvH/exgSbBQSZH97qJtBmpuzqnE5LoLWIHQdP0Gn0Qq5+eQETf9mRZ6+jWLnjEM3+PZeXv/0joCG+B+LPcN2bP/L3CctzoHTG5G1BDQgR6SYiG0UkVkQed1n/mIjEeB5rRSRRRMp51j3kWbZORIYHs5xZGd7qL5BmpmB0TrvJqBax4+AJbhn3C6fOJVK1THGemrmWDq8szHNBcfpcIo99thpVeGfhFl7+bmO6IXEg/gz931/Ghj3H+DH2ABv2HMvB0hqT9wQtIESkMPA20B1oCNwqIg19t1HVV1Q1WlWjgZHAIlU9JCKNgXuAy4BmQE8RqRussmZleKu/QJqZgtU57S+9WoQ3HE6fS+TTey5nuueCu2oXGBRJSUpiGo9gGf3dRrYeOMGHA1vTv00NxqYTEt5w2HHoBO/0b0HRIoWY/OufQSubydvsglNHMCfruwyIVdWtACIyBegNrE9j+1uByZ7nlwK/qOpJz76LgD7Ay9ldyKwOb3XjnQJ81FfrGNqhNheVDk9eF8zOaTe+tYjrm1WlSOFCqcLh0ipOOa6sW4F2dcrzU+xBxszbxFMz1/LOgliGdsh4UsDdR04xduEWpq7Y6dquX0hgZPdLuefqS7L1/FbuOMT/ftpG/zY1uLJuBdrWLg/A2IVbAPjntfURcX6fvuHw4YDWtK1Tgbnr9jJj1S5Gdr+U4kVt0kPjOHLyLB8s2cYny3YwqG0tHuoStO+leUIwA6IasNPndRzQxm1DESkBdAOGeRatBV4QkfLAKaAHsCKNfQcDgwFq1Mj8N/NzSUnc37EODapEZHpff/3bXMzmv+KZ+MsOJv/6J7e1qcF97Z2g8HZOv3xj0wt+n0B4axH3TlzJV7/vpuXFZV3DwXd736B4fZ4ze+w7C7e4BkVyMCzfSZIqNzSvRo1yJVKVY9m2g/zft3/Qtk55GlXNeg3Nl7dpqWpkcUb2uBSAQoWE53o3BlKGxMETZ1OFA8BtbS5mZsxuvl69m5tbVc+Wcpm8yxsME5Zu58TZBOpdFMHr8zaRpMrD19QLdfFCRoJVlRKRm4BrVfVuz+s7gMtU9QGXbfsBt6tqL59ldwH3A/E4tY5Tqvpweu/ZqlUrXbHCNUdy1J8HT/L2glimr4qjcCHhtstqsOvIKX7ZcpBl/+oc1P4HX6rKdW/8yPEz50hI1DTDIa19vUGxcsdhqkSGM7RDba6uV5EPlmxLDoabWlXn/o61iSqbOhwADp84yzWvL6ZiRDG+vL8dRYtceKvm87PW88GP25h0dxvaeT7wvZKSlKe+XMukZX8ysG1Nft5yMFU4eM/vmtcXExFehBlD211wmUze5B8MPZpU4cFOdal7USlGfL6az1bG8VDnuvk6JERkpaq2cl0XxIC4Ahilqtd6Xo8EUNX/uGw7A/hMVT9N41gvAnGq+k567xlRK0JbPtMyxbKbG93M0NZDOXnuJD0m9Ui1z8DogQyMHsiBkwfoO61vqvX3tbqPfo37sfPoTu6YcUeq9Y9c8Qi96vdi44GN3Dvr3hTrzpxLonpYf1Zuqs4p3UJY+Y+pVSHl3ede7Pwibau3ZenOpTwx/4lUxx/TbQzRlaOZt3Uezy9+PtX693q+R/0K9fl649e8+vOrqdbf3ehVnvx8LxT/iYuqLKGEX3PK9JunU6FEBSbETGBCzIRU+8++bTa/7TjFsK9e4o+j3wFObaNiRDGqlSnOz3cvBmD00tHM2jQrxb7Fw4rzTf9v+G7dXvpNfpQK5TcTVbZ48vryJcrz+c2fAzBy3kh+jvs5xf5RpaP45G+fADD82+HE7I3h+OkE1u05SqWIcK6t35xxvcYBMPjrwWw6uCl5320HTnD4aFWqMoQPB7TmndXDiTsWl+L4JbiU9X/05JuHruLJJYM4ePJgivWda3XmqfZPAdB9UndOnTuVYn2XWt1ZvvZKHu1aj6d+uinVzy6Uf3sAT179JF0u6ULM3hiGfzs81fpg/+1N7DOR6pHVmbp2KmNXjE21PqO/vTn951AirATvLH+HaeumpVq/cOBCIP2/PYDnFj3H/G3zU6wvXbQsV5d/iQlLtxOX9AElI7ZRrUzx5P8fUaWj+PiGiYz4fDXvrX6ai8rtTfG3W698vTT/9gCiK0czptsYAG7/4vZUf3tXRF3Bf7o4H4U3Trsx0397Pev15NG2jwLQYUKHVD+bzPztVSxZMc2ACOZX2eVAXRGpBewCbgFu899IRCKB9sDtfssvUtV9IlID+BtwRRDLGhTFwgox+Ora1OvVljeWnGPpweIZ75TNrq5bkad7luOY7Gfm5qWZ3t/b9HTPVbX4YGVp4k8nUCGiGMUyURO4tlFlLq1cmpj9pyhbMoySWaxBJamydX88xQoXdm3O8lWrQknqlSvHS50vp+XFZXlndept6leKIDY2653V63Yf5fedR3hh9gYok6VDmByWkKTsOXKK/ccSWH06luuaVOFcqRpsOrw/1baFCgn/d2NTfthbinX7TwKkCImCIGg1CAAR6QGMAQoDH6rqCyIyBEBV3/VsMxDopqq3+O27BCgPnAP+oaopvwK4yC1NTCY136amr4a1I6xw5pua0mtayqrhU35j/oZ9/PqvLpnqrFZVuv93CX8eOsnJs4m8e3sLujUOzrUt5sL5NiXFn0nguiZVeLBzXepXzrjvMSlJc31zk6omD8rIrJA0MYWCBUTu9t26vdw7cSXDu9RleJfU/8n2HT/NuEVb+WXbwVTrVGH9nmPcdlkNXujTJNvK9Ou2Q9z83s+83Ldppjqrf/vzMH3eWcpzvRsx/qftFC1SiDkPXpXhSLiPf97Oln3xPNmzYZZC0mTejN/ieGrmukwHgy/fkKhfKYKwIoF/GFcuHc5//taUihHFMlv0DO07dpp3F21l41/H+OSuNlkKifQCwu5JbXLMtY0q0zu6Km/9EMs1DSslj2rad/w07y3ayie/7OBcYhJta1dwbcJqGhWZPGopu7SuWZbaFUsy+dc/MxUQk3/9kxJFC3ND82pEhIcxfGoMc9fvTbcW8fvOI4z6ah1JCn8dO8ObtzW3kAiy6SvjeGz677SuWY7nejfOdDB4eZubqpYpztpdRzO170+xB7nt/V/49J7Lsy0kvMEwadkOEpKUvzWvxpmEJMLDsnfIttUgTI7ybWr634BWfPijM+b8bEISfZpHMaxTnVQd+cH2wZKtPD97A988dFVAI7yOnT5Hmxfmc0Pzqvznb01JTFKueW1RurWIMwmJ9HzjR46fTuD2y2sweu4mujWqbCERRN5waFe7Au/f2Spk17v8svUgg8YvJ6ps8QsOCbdgGNapDheXz/r/GatBmFyjbMmivNCnMfdOXEm7//sBgZAFg9eNLaJ4+buNTP71T571XEuRni9/28Wpc4nJV8QXLiQ82LluurWI/87bzOZ98Ywf1JqO9S+iRNEiPDtrPQ98+luaIaGqLNq0n89WxLle2S4idG5wETe2jMowZE6cSWDSsh3sP36GO6+oSfUMOvmz29LYAyyJPcDDXeply1DnjOSWcAC4/JLyjB/UmkHjl2e5JhGMYAiE1SBMSLz87R8cjD/LkA61QxYMvgLtrPZ2ThcpLMx64Krk5enVIn7feYQ+7/zEjS2ieOWmZsnLP/xxG8/OWp+qJuENhjHzNhOz8wgVI4pxkcsHSvyZBHYcPElU2eIM61jHNShOnEng4593MG7xFg6fPEcRT7luahXF0A51ciQoDsSf4ZrXFnH45DmubVSJN29tEdSQyE3h4CsrNYmcCAbrpDYmA4F2Vns7p1/o05j+bS5OsW7mb7sYPjUmxYgm36al7x6+msjiYSn28Q+Jn2IPJAdDtTLFGdapDje2iHL9QFVVFnqC5PedR1IExdmEpBTB0KF+RR7qXJfKkeG8u3ALk3/1XugY3KBQVYZOWsX8DfsY0PZi3l+yLaghkVvDwSvQkMjJGoMFhDEZUFW6vLaIksWcK6sLpzEa6Z/Tf2fW6j0se6IzEeEpP+zdahEvf/sH7yzckty05MYbEhVKFeNA/JkMg8Gt7L5BUa1McU6eTUgRDM1rlE2xz56jp1IERbfGlSlTIizVscMKF6J3dDWiq5fJsBxuvv59Nw9M/o1/dqvP0A51mPDTNkZ9vT4oIfH5yjgezcXh4OUNiSqR4bStUz7V+hNnEpmzZk+ONSVZQBgTgGnLd/LPz1c7fRJ9m6YKCf/OaTe+tYgqkcVdm5bcfLR0O5N//ZMBbWsGHAz+vEHx3qItlCpWhPs71kkVDP68QTFn7V6SXGbePXE2gdPnkuhYvyIPdamXqaDwNi3VKFeCz+9rSxFP81cwQiKvhIPXL1sPMuLz1cSfTki1TkToWL9ijvQxeN7PAsKYQIyZt4kx8za7hsTEn7fz1Jfr+GpYO5pGlXHd37cWkZikaTYt5RXxZxL4aOl23l+ylSMnzwUcFL5NS7MfvJK6lVIOL83OkMhr4ZDbpBcQNr7OGB/Du9RjeJe6fL4qjn9OX518PwtVZdKyP2lUtTRN0rlviHdE0x97j7N5Xzz/ubFJng0HILkm8uOITvyzW31idh7hhrd/YtD4X4nZeSTN/Wat3sM3a/cy/Jq6qcIBYGC7Wozq1ZDv1v3FA5NXZfnWtxYOwWUBYYwft5CI2XmEP/Ye57Y2NTK8WrVXs6q0rlmWu66slWa/Q15TqlgRhnaow5IAguJA/Bme/nItzaIiGXxV2vcB8Q2JYZ9mPiQsHILProMwxoV3KpAx8zYnLytRtDDXN6ua4b6FCwnT7r0iy3Pj5GbeoLjzipp8/PN23l+8lRve/im56alZVCRPzVzLiTOJjL6pWXK/Q1oGtqsFwKiv1zPs01W8dVuLgC4ctHDIGRYQxqTBPyRuaV091ciltOTHcPDlHxTjPEHRrHoZft95hH92q+/atOQmMyGhqkxZvpMnZqyxcMgBFhDGpGN4l3oIwthFsdxxxcUZ71DA+AaFtzO7RY0y6TYtuckoJFSV+Rv2MWb+JtbuOsaVdSwccoKNYjImAGcSEtO9N7dxnElIRJAsj0ryHd301m0tKFJIUgRDjXIlGNapDn2aV7M5rLKJzcVkzAWycAjMhf6cfGsSd320gkMnziQHw8t9m1ow5DALCGNMruIbEhYMoWUBYYzJdQa2q0WH+hdRrWxxC4YQsoAwxuRKNXPBLL8FnUWzMcYYVxYQxhhjXFlAGGOMcWUBYYwxxlVQA0JEuonIRhGJFZHHXdY/JiIxnsdaEUkUkXKedQ+LyDrP8skiEh7MshpjjEkpaAEhIoWBt4HuQEPgVhFp6LuNqr6iqtGqGg2MBBap6iERqQY8CLRS1cZAYeCWYJXVGGNMasGsQVwGxKrqVlU9C0wBeqez/a3AZJ/XRYDiIlIEKAHsDlpJjTHGpBLM6yCqATt9XscBbdw2FJESQDdgGICq7hKR0cCfwClgrqrOTWPfwcBgz8t4EdmYxfJWAA5kcd+8zM67YLHzLlgCOe80Z6EMZkC4zXec1syAvYCfVPUQgIiUxalt1AKOAJ+JyO2q+kmqA6qOA8ZdcGFFVqQ1YVV+ZuddsNh5FywXet7BbGKKA6r7vI4i7WaiW0jZvNQF2Kaq+1X1HPAF0DYopTTGGOMqmAGxHKgrIrVEpChOCHzlv5GIRALtgS99Fv8JXC4iJcS580pnYEMQy2qMMcZP0JqYVDVBRIYB3+GMQvpQVdeJyBDP+nc9m/bB6WM44bPvMhGZDqwCEoDfyIZmpAwE+/i5lZ13wWLnXbBc0HnnqxsGGWOMyT52JbUxxhhXFhDGGGNcFfiAyGg6kPxERD4UkX0istZnWTkR+V5ENnv+LRvKMmY3EakuIgtEZINn6paHPMvz+3mHi8ivIvK757z/7Vmer8/bS0QKi8hvIjLL87qgnPd2EVnjmb5ohWdZls+9QAdEINOB5DMTcC5I9PU4MF9V6wLzPa/zkwTgEVW9FLgcuN/zO87v530G6KSqzYBooJuIXE7+P2+vh0g58rGgnDdAR88URt7rH7J87gU6IMj8dCB5mqouBg75Le4NfOR5/hFwQ06WKdhUdY+qrvI8P47zoVGN/H/eqqrxnpdhnoeSz88bQESigOuAD3wW5/vzTkeWz72gB4TbdCDVQlSWUKmkqnvA+TAFLgpxeYJGRGoCzYFlFIDz9jSzxAD7gO9VtUCcNzAG+CeQ5LOsIJw3OF8C5orISs80RHAB517Q70mdmelATB4mIqWAz4HhqnrMuf4yf1PVRCBaRMoAM0SkcYiLFHQi0hPYp6orRaRDiIsTCu1UdbeIXAR8LyJ/XMjBCnoNIjPTgeRXf4lIFQDPv/tCXJ5sJyJhOOEwSVW/8CzO9+ftpapHgIU4/U/5/bzbAdeLyHacJuNOIvIJ+f+8AVDV3Z5/9wEzcJrRs3zuBT0gApoOJJ/7ChjgeT6AlFOe5HmeqVr+B2xQ1dd8VuX3867oqTkgIsVx5jf7g3x+3qo6UlWjVLUmzv/nH1T1dvL5eQOISEkRifA+B7oCa7mAcy/wV1KLSA+cNkvvdCAvhLZEwSMik4EOOFMA/wU8A8wEpgE1cObAusk7q25+ICJXAkuANZxvk34Cpx8iP593U5wOycI4XwSnqeqzIlKefHzevjxNTI+qas+CcN4icglOrQGc7oNPVfWFCzn3Ah8Qxhhj3BX0JiZjjDFpsIAwxhjjygLCGGOMKwsIY4wxriwgjDHGuLKAMPmCiCwUkaDflF5EHvTMDDspi/tPEJG+2V2u7CIiHUQk0/d/F5GavrMEm/yhoE+1YQwiUkRVEwLcfCjQXVW3BbNMoSAiRXCuk4kHlmZiv8LBKpMJLatBmBzj+Za5QUTe99yjYK7nKt8UNQARqeCZKgERGSgiM0XkaxHZJiLDROQfnrn+fxGRcj5vcbuILBWRtSJymWf/kuLcB2O5Z5/ePsf9TES+Bua6lPUfnuOsFZHhnmXvApcAX4nIw37bFxaRVzzvs1pE7vUsFxF5S0TWi8hsfCZKE5EeIvKHiPwoIm/I+XsXpFXmRuLc4yHG8x51XcodLyKvisgqEZkvIhU9y2uLyLeeSdyWiEgDz/IJIvKaiCwApgJDgIc973GVf41HROI9/3YQ5z4bn+JchAhQREQ+8pRtuoiUyOhvwuRyqmoPe+TIA6iJc3+GaM/racDtnucLgVae5xWA7Z7nA4FYIAKoCBwFhnjWvY4z+Z53//c9z68G1nqev+jzHmWATUBJz3HjgHIu5WyJ86FXEigFrAOae9ZtByq47DMYeNLzvBiwAqgF/A34HueK5qrAEaAvEI4zk3Atzz6TgVkZlPlNoL9neVGguEs51Gebp4G3PM/nA3U9z9vgTEEBzj1CZgGFPa9H4Vx9jM/6vj6v4z3/dgBO+JS/pue923lef+h7HHvkzYfVIExO26aqMZ7nK3E+WDKyQFWPq+p+nID42rN8jd/+kyH5vhelPXMRdQUeF2fa64U4H8w1PNt/r+5TDlwJzFDVE+rcU+EL4KoMytgVuNPzPsuA8kBdnLCarKqJ6kyk9oNn+wbAVj3fVDXZ71huZf4ZeEJERgAXq+opl3Ik4dQEAD4BrhRnJtu2wGeeY74HVPHZ5zN1Zn7NrF81ZVPbTlX9yfe9s3BMk4tYH4TJaWd8nicCxT3PEzjf5Bmezj5JPq+TSPk37D9vjOJM6X6jqm70XSEibXC+AbvJylzgAjygqt/5vU8Pl3Jl9B6uZQY2iMgynJvhfCcid6vqD6l3T0Fxfq5HVDU6jW3S+jmAz+9FRASn5pLWfm4/f5OHWQ3C5BbbcZp2wGmCyYp+kDxB31FVPQp8Bzzg+XBDRJoHcJzFwA0iUkKcWTH74Ez4l57vgPvEmVocEann2XcxcIunj6IK0NGz/R/AJeLcxCi57D7HSlVmcSZj26qqb+DM0NnUpRyFOP/zuw34UVWPAdtE5CbPcUREmqVxHsdxmvO8tnP+99Ib5850aakhIld4nt8K/JjOtiYPsIAwucVonA/YpTh9EFlx2LP/u8BdnmXP4XyorRZnGOZzGR1EnVuUTgB+xWku+kBVf8tgtw+A9cAqz/u8h1O7mQFsxmkOGwss8rzHKZwRUd+KyI84s+sezaDM/YC1nmaiBsDHLuU4ATQSkZVAJ+BZz/L+wF0i8jtOn0pat9b9Gujj7aQG3gfai8ivOH0X6dU2NgADRGQ1UM5zviYPs9lcjQkRESmlqvGemsLbwGZVff0CjxmvqqWyp4SmoLMahDGhc4+nNrAOiMSpdRiTa1gNwhhjjCurQRhjjHFlAWGMMcaVBYQxxhhXFhDGGGNcWUAYY4xx9f9JbIXeypL2RwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 50\n",
    "plt.plot(range(num), acc_pubmed[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.78, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "d453a2be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.797\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "acc2_pubmed = acc_pubmed[0:100]\n",
    "index_pubmed = np.where(acc2_pubmed == max(acc2_pubmed))\n",
    "print(np.array(acc_pubmed)[index_pubmed].mean())\n",
    "print(np.array(acc_pubmed)[index_pubmed].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "252125c9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_citeseer[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_citeseer[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.719, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.726, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_3)\n",
    "plt.ylim(0.7, 0.8)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "16131a85",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7337499999999999\n",
      "0.0021650635094610984\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([0.73 , 0.735, 0.735, 0.735])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "index_citeseer = np.where(acc2_citeseer == max(acc2_citeseer))\n",
    "print(np.array(acc_citeseer)[index_citeseer].mean())\n",
    "print(np.array(acc_citeseer)[index_citeseer].std())\n",
    "np.array(acc_citeseer)[index_citeseer]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2be0a91b",
   "metadata": {},
   "outputs": [],
   "source": [
    "perturb = []\n",
    "for j in range(100):\n",
    "    if (acc_cora[j] > acc_cora[0]) and (acc_pubmed[j] > acc_pubmed[0]) and (acc_citeseer[j] > acc_citeseer[0]):\n",
    "        perturb.append(j)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "ee78ba0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([26, 29]),)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_cora[11]\n",
    "np.where(acc2_cora == np.max(acc2_cora))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "2cf8d743",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.748"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc2_citeseer[20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "5937b84c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.79"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c1d6c7c",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "80514844",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:05<00:00,  9.29it/s]\n"
     ]
    }
   ],
   "source": [
    "down_weight = 0.5\n",
    "num = 50\n",
    "acc_cora_augment = []\n",
    "acc2_cora_augment = []\n",
    "\n",
    "\n",
    "cora_infl_0 = pd.read_csv('result_data/cora_edge_influence.csv', header = None)\n",
    "cora_infl_0 = cora_infl_0.loc[abs(cora_infl_0[1]) < 0.00005]\n",
    "cora_infl_0 = cora_infl_0.sort_values([1])\n",
    "cora_infl_0.index = range(len(cora_infl_0))\n",
    "\n",
    "from_index_cora_less_infl = cora_infl_0.loc[0:][2].values.astype(int)\n",
    "to_index_cora_less_infl = cora_infl_0.loc[0:][3].values.astype(int)\n",
    "nis_cora_less_infl = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                   from_index=from_index_cora_less_infl, to_index=to_index_cora_less_infl)\n",
    "nis_cora_less_infl.remove_edges_sgc_from_influence()\n",
    "feat_augment_cora = nis_cora_less_infl.calculate_modified_features()\n",
    "\n",
    "train_x_cora_augment_low_infl = feat_augment_cora[train_mask_cora == 1].numpy()\n",
    "index_augment = np.unique(np.where(train_x_cora != train_x_cora_augment_low_infl)[0])\n",
    "train_x_cora_extra = train_x_cora_augment_low_infl[index_augment]\n",
    "train_y_cora_extra = train_y_cora[index_augment]\n",
    "\n",
    "w1 = np.ones(train_x_cora_extra.shape[0] + train_x_cora.shape[0])\n",
    "w1[len(train_x_cora):] = down_weight\n",
    "\n",
    "for i in tqdm(range(num)):\n",
    "    from_index_cora = cora_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i][3].values.astype(int)\n",
    "    \n",
    "\n",
    "    \n",
    "    nis_cora = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                           from_index=from_index_cora, to_index=to_index_cora)\n",
    "    nis_cora.remove_edges_sgc_from_influence()\n",
    "    feat_removed_cora = nis_cora.calculate_modified_features()\n",
    "    \n",
    "    train_x_cora_remove_high_infl = feat_removed_cora[train_mask_cora == 1].numpy()\n",
    "    \n",
    "    \n",
    "    lr_cora = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    \n",
    "    train_x_cora_new = np.concatenate([train_x_cora_remove_high_infl, train_x_cora_extra])\n",
    "    train_y_cora_new = np.concatenate([train_y_cora, train_y_cora_extra])\n",
    "    \n",
    "    lr_cora.fit(train_x_cora_new, train_y_cora_new, sample_weight=w1, verbose=False)\n",
    "    acc_cora_augment.append(np.mean(lr_cora.model.predict(test_x_cora) == test_y_cora))\n",
    "    acc2_cora_augment.append(np.mean(lr_cora.model.predict(val_x_cora) == val_y_cora))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "452c6c80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEWCAYAAAB8LwAVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAA/gklEQVR4nO3dd3hUZfbA8e8hhB5CCSIQIFHpLVQpuoIggoKIIkVAii4q6oquruVnYe27q666KooKSFFEEBVEpAsCIkWULiWRhN5JiOnn98e9xEkyqWRIO5/nycPc+97y3mSYM28XVcUYY4xJr1RBZ8AYY0zhZAHCGGOMVxYgjDHGeGUBwhhjjFcWIIwxxnhlAcIYY4xXFiCMMcZ4ZQHCGGOMVxYgjCkAIlK6oPNgTHYsQBiTByJSV0S+EJFjInJCRN4WkVIi8pSI/C4iR0VkqogEuseHiIiKyJ0ish9Y5u7/XEQOi8gZEVkpIs0K9MGM8WABwphcEhE/YD7wOxAC1AFmAiPdn27AZUAl4O10p18DNAGud7e/BRoAlwCbgBm+zLsxuSE2F5MxuSMinYCvgVqqmuSxfykwR1XfdbcbAVuB8kAwEA5crqr7MrluFeAUUEVVz/j0IYzJAStBGJN7dYHfPYODqzZOqeK834HSQE2PfZHnX4iIn4i8IiJ7ReQsEOEmBeV/lo3JPQsQxuReJFDPS0PzQaC+x3Y9IAk44rHPs8h+O9AP6AEE4lRXAUh+ZtaYvLIAYUzu/QQcAl4RkYoiUk5EugCfAg+JSKiIVAJeAj7zUtI4LwCIB04AFdzjjSk0LEAYk0uqmgz0Ba4A9gNRwCBgEjANWInT3hAHPJDFpabiVEMdALYDP/ou18bknjVSG2OM8cpKEMYYY7zyaYAQkV4isktE9ojI417SA0Vknoj8IiLbRGSUR1oVEZktIjtFZIfbtdAYY8xF4rMqJncw0W/AdTh1tOuBIaq63eOYJ4FAVX1MRGoAu4BLVTVBRD4GVqnqhyJSBqigqqd9klljjDEZ+LIE0QHYo6r7VDUBZ6Rpv3THKBAgIoIz6vQkkCQilYG/AB8BqGqCBQdjjLm4fDlhWB08BgXhlCKuTHfM2zgjUg/idPkbpKopInIZcAyYLCKtgI3Ag6p6Lv1NRGQMMAagYsWKbRs3bpzvD2KMMcXVxo0bj6tqDW9pvgwQ3gb7pK/Puh7YDFwLXA4sFpFVbr7aAA+o6joReRN4HHg6wwVVJwITAdq1a6cbNmzItwcwxpjiTkR+zyzNl1VMUThTEpwXjFNS8DQK+EIde3D6jjd2z41S1XXucbNxAoYxxpiLxJcBYj3QwB1VWgYYjFOd5Gk/0B1ARGoCjYB9qnoYiHQnO8M9ZjvGGGMuGp9VMalqkojcD3wH+AGTVHWbiNzjpr8HPA9MEZEtOFVSj6nqcfcSDwAz3OCyD6e0YYwx5iIpViOpvbVBJCYmEhUVRVxcXAHlynhTrlw5goOD8ff3L+isGFOiichGVW3nLa3YL3sYFRVFQEAAISEhOL1pTUFTVU6cOEFUVBShoaEFnR1jTCaK/VQbcXFxVK9e3YJDISIiVK9e3Up1xhRyxT5AABYcCiH7mxhT+JWIAGGMMSb3LED42OnTp3n33XfzfP4bb7xBbGxsPubIGGNyxgKEjxWHAJGUlNmCaMaY4swChI89/vjj7N27l7CwMB599FEA/vOf/9C+fXtatmzJs88+C8C5c+e48cYbadWqFc2bN+ezzz7jrbfe4uDBg3Tr1o1u3bpluPZzzz1H+/btad68OWPGjOF8l+U9e/bQo0cPWrVqRZs2bdi7dy8A//73v2nRogWtWrXi8ced2de7du3K+a7Bx48fJyQkBIApU6Zw22230bdvX3r27ElMTAzdu3enTZs2tGjRgq+++io1H1OnTqVly5a0atWK4cOHEx0dTWhoKImJiQCcPXuWkJCQ1G1jTNFQ7Lu5evrnvG1sP3g2X6/ZtHZlnu3bLNP0V155ha1bt7J582YAFi1axO7du/npp59QVW666SZWrlzJsWPHqF27Nt988w0AZ86cITAwkNdff53ly5cTFBSU4dr3338/zzzzDADDhw9n/vz59O3bl6FDh/L444/Tv39/4uLiSElJ4dtvv+XLL79k3bp1VKhQgZMnT2b7bGvXruXXX3+lWrVqJCUlMXfuXCpXrszx48fp2LEjN910E9u3b+fFF19k9erVBAUFcfLkSQICAujatSvffPMNN998MzNnzuTWW2+1MQ/GFDFWgrjIFi1axKJFi2jdujVt2rRh586d7N69mxYtWrBkyRIee+wxVq1aRWBgYLbXWr58OVdeeSUtWrRg2bJlbNu2jejoaA4cOED//v0BZ0BahQoVWLJkCaNGjaJChQoAVKtWLdvrX3fddanHqSpPPvkkLVu2pEePHhw4cIAjR46wbNkyBgwYkBrAzh9/1113MXnyZAAmT57MqFE2EN6YoqZElSCy+qZ/sagqTzzxBHfffXeGtI0bN7JgwQKeeOIJevbsmVo68CYuLo6xY8eyYcMG6taty/jx44mLiyOzkfGq6rVraenSpUlJSUm9pqeKFSumvp4xYwbHjh1j48aN+Pv7ExISkno/b9ft0qULERERfP/99yQnJ9O8efNMn8UYUzhZCcLHAgICiI6OTt2+/vrrmTRpEjExMQAcOHCAo0ePcvDgQSpUqMCwYcN45JFH2LRpk9fzzzv/YR4UFERMTAyzZ88GoHLlygQHB/Pll18CEB8fT2xsLD179mTSpEmpDd7nq5hCQkLYuHEjQOo1vDlz5gyXXHIJ/v7+LF++nN9/d2YI7t69O7NmzeLEiRNprgtwxx13MGTIECs9GFNElagSREGoXr06Xbp0oXnz5vTu3Zv//Oc/7Nixg06dnCW2K1WqxPTp09mzZw+PPvoopUqVwt/fnwkTJgAwZswYevfuTa1atVi+fHnqdatUqcJf//pXWrRoQUhICO3bt09NmzZtGnfffTfPPPMM/v7+fP755/Tq1YvNmzfTrl07ypQpww033MBLL73EI488wsCBA5k2bRrXXnttps8xdOhQ+vbtS7t27QgLC+P8wkzNmjXj//7v/7jmmmvw8/OjdevWTJkyJfWcp556iiFDhuT3r9UYcxEU+8n6duzYQZMmTQooRyXb7Nmz+eqrr5g2bZrXdPvbGFPwSvRkfaZgPPDAA3z77bcsWLCgoLNijMkjCxDGJ/73v/8VdBaMMRfIGqmNMcZ4ZQHCGGOMVxYgjDHGeOXTACEivURkl4jsEZHHvaQHisg8EflFRLaJyCiPtAgR2SIim0VkQ/pzjTHG+JbPGqlFxA94B7gOiALWi8jXqrrd47D7gO2q2ldEagC7RGSGqia46d1U9biv8miMMSZzvixBdAD2qOo+9wN/JtAv3TEKBIgzV0Ml4CRQoueWrlSpUkFnwRhjAN8GiDpApMd2lLvP09tAE+AgsAV4UFVT3DQFFonIRhEZ48N8Gi9sDQhjjC/HQXhbdDj9sO3rgc3AtcDlwGIRWaWqZ4EuqnpQRC5x9+9U1ZUZbuIEjzEA9erVyzpH3z4Oh7fk9jmydmkL6P1KpsmPPfYY9evXZ+zYsQCMHz8eEWHlypWcOnWKxMREXnjhBfr1S1+4yigmJoZ+/fp5PW/q1Km8+uqriAgtW7Zk2rRpHDlyhHvuuYd9+/YBMGHCBGrXrk2fPn3YunUrAK+++ioxMTGMHz+erl270rlzZ1avXs1NN91Ew4YNeeGFF0hISKB69erMmDGDmjVrEhMTwwMPPMCGDRsQEZ599llOnz7N1q1b+e9//wvABx98wI4dO3j99dcv6NdrjCk4vgwQUUBdj+1gnJKCp1HAK+rM97FHRMKBxsBPqnoQQFWPishcnCqrDAFCVScCE8GZaiPfn+ICDR48mHHjxqUGiFmzZrFw4UIeeuihDGsreJsV1VO5cuVyvCYDwN/+9jeuueYa5s6dS3JyMjExMZw6dSrLe5w+fZrvv/8egFOnTvHjjz8iInz44Yf8+9//5rXXXuP5558nMDCQLVu2pB5XpkwZWrZsyb///W/8/f2ZPHky77///oX++owxBciXAWI90EBEQoEDwGDg9nTH7Ae6A6tEpCbQCNgnIhWBUqoa7b7uCTx3wTnK4pu+r7Ru3Tp1ttZjx45RtWpVatWqxUMPPcTKlSspVapU6toKl156aZbXOr8mQ/rzMluTYdmyZUydOhUAPz8/AgMDsw0QgwYNSn0dFRXFoEGDOHToEAkJCYSGhgKwZMkSZs6cmXpc1apVAbj22muZP38+TZo0ITExkRYtWuTyt2WMKUx8FiBUNUlE7ge+A/yASaq6TUTucdPfA54HpojIFpwqqcdU9biIXAbMdb9RlwY+UdWFvsqrrw0YMIDZs2dz+PBhBg8enOnaCtnJ7ZoM3niu/wBZrwHxwAMP8PDDD3PTTTexYsUKxo8fD2S+tsRdd93FSy+9ROPGjW2Kb2OKAZ+Og1DVBaraUFUvV9UX3X3vucEBVT2oqj1VtYWqNlfV6e7+farayv1pdv7comrw4MHMnDmT2bNnM2DAgEzXVshObtdk6N69e+q04cnJyZw9e5aaNWty9OhRTpw4QXx8PPPnz8/yfnXqOP0KPv7449T9PXv25O23307dPl8qufLKK4mMjOSTTz6xKb6NKQZsJPVF0KxZM6Kjo6lTpw61atVi6NChbNiwgXbt2jFjxozUtRWyk9l5nmsytGrViocffhiAN998k+XLl9OiRQvatm3Ltm3b8Pf355lnnuHKK6+kT58+Wd57/Pjx3HbbbVx99dVp1sR+6qmnOHXqFM2bN6dVq1Zp1qkYOHAgXbp0Sa12MsYUXbYehMlXffr04aGHHqJ79+7ZHmt/G2MKXlbrQVgJwuSL06dP07BhQ8qXL5+j4GCMKfxsPYhCaMuWLQwfPjzNvrJly7Ju3boCylH2qlSpwm+//VbQ2TDG5CMLEIVQixYt2Lx5c0FnwxhTwlkVkzHGGK8sQBhjjPHKAoQxxhivLEBcBC+++CLNmjWjZcuWhIWFsW7dOpKSknjyySdp0KABYWFhhIWF8eKLf44HPD/q+vLLL6dp06bccMMN1ghsjLmorJHax9auXcv8+fPZtGkTZcuW5fjx4yQkJPDUU09x+PBhtmzZQrly5YiOjua1114DnKks+vfvz4gRI1LnPNq8eTNHjhyhYcOGBfk4xpgSxAKEjx06dIigoCDKli0LQFBQELGxsXzwwQdERERQrlw5AAICAlLnOlq+fDn+/v7cc889qdcJCwu72Fk3xpRwJS5AdJ3SNcO+gc0GMrb9WGITY7lhxg0Z0keGjWRk2EiOxx5nwKwBadJWjFyR5f169uzJc889R8OGDenRoweDBg2iatWq1KtXj4CAAK/nbN26lbZt2+b4mYwxxhesDcLHKlWqxMaNG5k4cSI1atRg0KBBrFixIs0xkydPJiwsjLp16xIZGen9QsYYc5HZXEwX2ezZs3n//ffZtGkTERERaUoRzZs3Z/78+ezdu5d//vOfrFyZYX2kYqWw/W2MKYlsLqYCtGvXLnbv3p26vXnzZho1asSdd97J/fffn7oeQ3JyMgkJCYCz8E58fDwffPBB6nnr169PXenNGGMuhhLXBnGxnV+/+fTp05QuXZorrriCiRMnEhgYyNNPP03z5s0JCAigfPnyjBgxgtq1ayMizJ07l3HjxvHKK69Qrlw5QkJCeOONNwr6cYwxJYhVMZkCY38bYwqeVTEZY4zJNQsQxhhjvPJpgBCRXiKyS0T2iMjjXtIDRWSeiPwiIttEZFS6dD8R+VlEMl842RhjjE/4LECIiB/wDtAbaAoMEZGm6Q67D9iuqq2ArsBrIlLGI/1BYIev8miMMSZzvixBdAD2qOo+VU0AZgL90h2jQICICFAJOAkkAYhIMHAj8KEP82iMMSYTvgwQdQDPYcFR7j5PbwNNgIPAFuBBVU1x094A/gGkkAURGSMiG0Rkw7Fjx/Ij38YYY/BtgBAv+9L3qb0e2AzUBsKAt0Wksoj0AY6q6sbsbqKqE1W1naq2q1GjxgVmuWC98cYbxMbGFnQ2jDEG8G2AiALqemwH45QUPI0CvlDHHiAcaAx0AW4SkQicqqlrRWS6D/NaKFiAMMYUJr4MEOuBBiIS6jY8Dwa+TnfMfqA7gIjUBBoB+1T1CVUNVtUQ97xlqjrMh3n1mXPnznHjjTfSqlUrmjdvzmeffcbSpUtp3bo1LVq0YPTo0cTHx/PWW29x8OBBunXrRrdu3QC49957adeuHc2aNePZZ58t4CcxxpQ0PptqQ1WTROR+4DvAD5ikqttE5B43/T3geWCKiGzBqZJ6TFWP+ypPAHTtmnHfwIEwdizExsINGaf7ZuRI5+f4cRiQdrpv0s3Mmt7ChQupXbs233zzDQBnzpyhefPmLF26lIYNG3LHHXcwYcIExo0bx+uvv87y5csJCgoCnJXoqlWrRnJyMt27d+fXX3+lZcuWuX5kY4zJC5+Og1DVBaraUFUvV9UX3X3vucEBVT2oqj1VtYWqNlfVDNVIqrpCVfv4Mp++1KJFC5YsWcJjjz3GqlWriIiIIDQ0NHVluBEjRmQ6a+usWbNo06YNrVu3Ztu2bWzfvv1iZt0YU8KVvMn6svrGX6FC1ulBQdmWGNJr2LAhGzduZMGCBTzxxBP07NkzR+eFh4fz6quvsn79eqpWrcrIkSNTZ341xpiLwaba8LGDBw9SoUIFhg0bxiOPPMKaNWuIiIhgz549AEybNo1rrrkGcJYdjY6OBuDs2bNUrFiRwMBAjhw5wrfffltgz2CMKZlKXgniItuyZQuPPvoopUqVwt/fnwkTJnDmzBluu+02kpKSaN++fera02PGjKF3797UqlWL5cuX07p1a5o1a8Zll11Gly5dCvhJjDEljU33bQqM/W2MKXg23bcxxphcswBhjDHGqxIRIIpTNVpxYX8TYwq/Yh8gypUrx4kTJ+wDqRBRVU6cOEG5cuUKOivGmCwU+15MwcHBREVFYTO9Fi7lypUjODi4oLNhjMlCsQ8Q/v7+hIaGFnQ2jDGmyCn2VUzGGGPyxgKEMcYYryxAGGOM8coChDHGGK8sQBhjjPHKAoQxxhivLEAYY4zxygKEMcYYr3waIESkl4jsEpE9IvK4l/RAEZknIr+IyDYRGeXuLyciP3ns/6cv82mMMSYjnwUIEfED3gF6A02BISLSNN1h9wHbVbUV0BV4TUTKAPHAte7+MKCXiHT0VV6NMcZk5MupNjoAe1R1H4CIzAT6Ads9jlEgQEQEqAScBJLUmVkvxj3G3/3Jfra9Xbuga9e0+wYOhLFjITYWbrgh4zkjRzo/x4/DgAEZ0++9FwYNgshIGD48Y/rf/w59+zr3vvvujOlPPQU9esDmzTBuXMb0l16Czp1hzRp48smM6W+8AWFhsGQJvPBCxvT334dGjWDePHjttYzp06ZB3brw2WcwYULG9NmznbW2p0xxftJbsMBZq/vdd2HWrIzp59fofvVVmD8/bVr58nB+qdTnn4elS9OmV68Oc+Y4r594AtauTZseHAzTpzuvx41zfoeeGjaEiROd12PGwG+/pU0PC3N+fwDDhkFUVNr0Tp3g5Zed17feCidOpE3v3h2eftp53bs3/PFH2vQ+feCRR5zX6d93YO89e+85rwv7ey8LvqxiqgNEemxHufs8vQ00AQ4CW4AHVTUFnBKIiGwGjgKLVXWdt5uIyBgR2SAiGxITE/P5EYwxpuTy2ZKjInIbcL2q3uVuDwc6qOoDHscMALoADwOXA4uBVqp61uOYKsBc4AFV3ZrVPb0tOWqMMSZzBbXkaBRQ12M7GKek4GkU8IU69gDhQGPPA1T1NLAC6OWznBpjjMnAlwFiPdBARELdhufBwNfpjtkPdAcQkZpAI2CfiNRwSw6ISHmgB7DTh3k1xhiTjs8aqVU1SUTuB74D/IBJqrpNRO5x098DngemiMgWQIDHVPW4iLQEPnZ7QpUCZqnqfO93MsYY4ws+a4MoCNYGYYwxuVNQbRDGGGOKsBwFCBGZIyI3iogFFGOMKSFy+oE/Abgd2C0ir4hI4+xOMMYYU7TlKECo6hJVHQq0ASKAxSKyRkRGiYi/LzNojDGmYOS4ykhEqgMjgbuAn4E3cQLGYp/kzBhjTIHKUTdXEfkCZwDbNKCvqh5ykz4TEes2ZIwxxVBOx0G8rarLvCVk1j3KGGNM0ZbTKqYm50c2A4hIVREZ65ssGWOMKQxyGiD+6s6JBICqngL+6pMcGWOMKRRyGiBKuWs2AKmLAZXxTZaMMcYUBjltg/gOmCUi7+Es3HMPsNBnuTLGGFPgchogHgPuBu7FmVRvEfChrzJljDGm4OUoQLirvE1wf4wxxpQAOR0H0QB4GWgKlDu/X1Uv81G+jDHGFLCcNlJPxik9JAHdgKk4g+aMMcYUUzkNEOVVdSnO+hG/q+p44FrfZcsYY0xBy2kjdZw71fdud5W4A8AlvsuWMcaYgpbTEsQ4oALwN6AtMAwY4aM8GWOMKQSyDRDuoLiBqhqjqlGqOkpVb1XVH3Nwbi8R2SUie0TkcS/pgSIyT0R+EZFtIjLK3V9XRJaLyA53/4N5ejpjjDF5lm2AUNVkoK3nSOqccAPLO0BvnN5PQ0SkabrD7gO2q2oroCvwmoiUwWkM/7uqNgE6Avd5OdcYY4wP5bQN4mfgKxH5HDh3fqeqfpHFOR2APaq6D0BEZgL9gO0exygQ4AafSsBJIMmdTvyQe49oEdkB1El3rjGmCIiOS+TzDVEci4lnXI8GlC3tV9BZMjmU0wBRDThB2p5LCmQVIOoAkR7bUcCV6Y55G/gaOAgEAIPcQXmpRCQEaA2s83YTERkDjAGoV69eNo9hjLlYfj9xjilrIvh8QxQx8UkAbPr9FBOHtyOwgi1EWRTkdCT1qDxc21uVlKbbvh7YjBN4LsdZynSVqp4FEJFKwBxg3Pl9XvI2EZgI0K5du/TXN8ZcRKrKj/tOMml1OEt2HMFPhL6tajOqSwjhx8/x6Oe/cut7a5g8sj11q1Uo6OyabOR0JPVkMn64o6qjszgtCqjrsR2MU1LwNAp4RVUV2CMi4Tgr1/3krnU9B5iRTVWWMaaAxSUmM++Xg0xaHcGOQ2epWsGf+7pewfBO9alZ2Zl8oWVwFWpWLseYqRu4ZcIaJo1oT4vgwALOec6ci09izqYoPlm3n8Dy/ozqEsp1TWviVypXTbNFjjifzdkcJHKrx2Y5oD9wUFX/lsU5pYHfgO444ybWA7er6jaPYyYAR1R1vIjUBDYBrXCqsz4GTqrquJw+TLt27XTDBlsB1ZiL5Vh0PNN//J0Z637neEwCDWtWYnSXUG5uXYdy/t7bGnYfiWbk5PWcik3gndvb0K1x4R1SFXUqlqlrf+fTn/YTHZdEy+BATsQkcOD0HwRXLc/IziEMbF+XyuWKbpWZiGzMbGXQHAUILxcsBSxR1SxHU4vIDcAbgB8wSVVfFJF7AFT1PRGpDUwBauFUSb2iqtNF5CpgFbAFON8m8aSqLsjqfhYgjLk4dh4+ywcrw5n3y0ESklO4tvEljO4SSpcrqpOTDo9Hz8Yx+uP1bD94luf6NWfolfVydB44bRtHo+Mv9BGyFBOfxOcbIlm49TAiQq/mlzK6Syht6lUhOUVZvP0Ik1dH8FPESSqW8eO2dnW5vtmllPbzbYkiNKgiQZXK5us1fREgGgHfqOoVF5q5/GQBwhjf+3xDJE98sYUypUsxoG0wIzuHcFmNSrm+zrn4JO7/ZBPLdx2jUc0ARl8VQr8w7yWPlBTl+9+OMWl1OKt2H8+Px8hWYHl/hnSoxx2d6lO7Snmvx2yJOsPk1eHM+/Ugicm+bwIt41eKvq1qM/qqEJrVzp/quQsOECISTdo2iMPAE6o6J19ymE8sQBjjO6rKm0t388aS3Vx1RRBv396aKhUubGHJpOQU5v58ILXtolrFMgy9sh7DOjptF7EJSczZGMXk1RHsO36OSwLKcken+oTVrZpPT+VdKYGwelWoUCZnHT2PRsfx2+EYn+YpWZVlO47w+cYoYhOSuTK0GqOvCqVHkwtrC8n3EkRhZQHCXEwJSSl8+tN+WgQH0qaebz+wClpicgpPfrGFzzdGcWubYF6+pQVlSud0pp7spe/9VLqUcHWDGmyIOMlZt+7/zqtC6d28Vr7etyg680cis9ZHMmVNBAdO/0HdauUZ2TmU4R3r5+l3kx8liP7AMlU9425XAbqq6pe5zo0PWYAwF8vZuETunb6R1XtOANC6XhVGdwmlV/NL8fcrXh9g0XGJjJ2xiVW7j/Ng9waM69Egx+0FeXF+/MQ3vx6ifUg1Rl8VQpt6VX16z6IoKTmFRduPMOmHcE6cS2Dpw9dQKg8lifwIEJtVNSzdvp9VtXWuc+NDFiDMxXDw9B+MmryevcdieK5fcxKTU5i8OpyIE7HUCizHHZ1CGNKh7gVXvxQGh8/EMXLyT+w5GsNLt7RgYLu62Z9kLrrTsQl5fr9lFSByOpLa21einJ5rTCpVZdP+U0xZ8zsRx89lf4KHCmX8uLVtMDe1qp1pF8q8ijwZy9S1EUSciGVA2+BM63W3HzzL6CnriYlPYsqoDlzVIAiA4R3rs3zXUSatDudfC3fy5tLfuLVNMKO6hHDFJQFZ3vvwmTim/RjBD7uPk+Ll+1qZ0qW4sUUtBravS6Wy+f/fbtG2w0z4fi9JXhpZo07FkpisTB7Vnqsb1Mj3e5v84asvIzktQUwCTuNMvqfAA0BVVR3pk1zlkZUgCq+EpBS+3XqIST+E80vUGSqXK03b+rmrNog8GcvuozFUr1iGoR3rM6xjPS4JKJf9iZlQVTb8fopJP4Tz3TanO2P1imU4Gh2fWq87sF0wAW4f95W/HWPsjE1UKluayaPa06RWZa/X3Xn4LJN/iGDu5gMkJKVwTcMajL4qlL80CErzvJsjTzN5dTjf/HqIZFU6hFSjopcAcCw6ni0HzhBQtjQD29dlZOeQfBuFPHl1OM/N305oUEVCqlfMkF7OvxT3d2tA09ren9UUfflRxVQReBro4e5aBLyoqrn7CuhjFiAKn5PnEvj0p/1MXRvBkbPxXFajIqO6hHJrmzo57iFynqqydu8JJq0OZ+nOo5Qu5UzjMKJT7j4wVZWVu48x6YcIthw4Q2B5f26/0unOWKNSWRZvP8Kk1eGsjzhFpbKlua1dMMFVK/Dygh1ccUklJo9qT61A790ePZ2IieeTdfuZ9uPvHI2O53L32atU8Gfy6gg2/n4q9UN/RKcQ6lXP/Bk8g0mKKtc1rcnoLqF0CK2Wp7r5lBTlxQU7+OiHcHo2rcmbg1tTvoxNolcSWS8mUyDW7DnO3dM3Eh2XxNUNghh9VSjXNKiRp4a09CKOn58ILpJzCcl5usYVl1RiVJcQbmkd7PXD8deo00xeHcF8t4/71Q2CeHdom9QSRU4lJKWwYMshPvohnC0HzgBQv3oFRnUOYUC73FUbna+O+mTdfk7FJtKsdmVGdwmlT6taOZ4lNS4xmXEzN7Nw22FGdg7h6T5Ni/2UESZz+VGCWAzcpqqn3e2qwExVvT4/M3qhLEAUHnN/juIfs38lNKgibw1pTeNLfVNFcTYuke+2HiY2l0Hi8hqVcjXq98fwk/S+wB5KTvvLac7FJ9HliqAL+lCOS0xm7s8HmLw6nN+OxBBUqSzDO9ZnaMd6WY60PXkugbs+Xs/Pkaf5vxuacOdVodY7qITLjwCRoceS9WIqZFKSYcc8SIrz7X2q1If6nTJNVlXeWb6HVxf9RqfLqvPe8LYEli+689QUdqrKD3uOM+mHcJbvOkYZv1LcFFabTpdVJ/3nfqm403yxahM/RtfgjUFh3NCiVsFkurBISoDfvoXEPwo6J2mJH1zRHSpUy9nxJ8Ph0C/Q7Oa83S4fejGliEg9Vd3vXjAEL7O7mgK0ZTbMHXNx7nXHV3BZ1wy7E5NTePrLrcxcH0n/1nX4160tS/ygJl8TcQaUXd2gBnuPxTBldQSzN0Yxe2NU2uNIYW6ZZ3m/VCS7b19By6YlPDj8cRo+GwYRqwo6J95VDYVhc6D65Vkfd2AjfDLIeX1FDyib+ylPspLTEkQvnDUXvnd3/QUYo6rf5WtuLlCJLkFM6QNnImHYF2T46phfUlJgen8oEwB3rwS/P79fxMQncd+MTXz/2zEeuPYKHr6uoVVdFJCY+CROxKSdzK7iztkELXYnX245CG6ZWAA5KyROR8KM2+DEHuj7BtTvXNA5SutUBMy5C1Th9s+gbgfvx+1cAHPuhIo1YOhsqNEwT7e74BKEqi4UkXY4K7dtBr4CClm5rAQ7Ge58E+r2VPbfOC7Udc/D5yPg56nQbnRqz6Lnv9nBb0eieeWWFgzuYCv7FaRKZUunbfhOOAc/vgx12kLoX+CH/0KHMRDs9TOheDv0C8wY6FQrDf/C+X0UNtUugzsXO0Hs475OMG/aL+0xP30A3/4DaoU5QaSSb6ZMz+mCQXcBD+Is+rMZ6AisJe0SpKag/PIpIBA2xPf3atoP6nVGl73Alwkdef+n4+w8HE31imX4aEQ7ujYqvHP7l1ir34ToQzBwKlzSBDZ/Agsfdz6ESlIpb/dimDXCqdu/40vnd1FYVb/c+ft8OtjJ8/UvQaexTil+6Xjnb9qwNwz4CMpkHL+SX3JaQfwg0B74XVW74awRfcxnuTI5l5Li/Ie/vBsEBvv8dkej45le5W409iRHF7wAwL8HtGT149dacCiMTkc6HybNBzhVFWUDoPszELXeabcqKTZOcerqq18Ody0p3MHhvIrVYcTX0KQvfPcEfPuYU6W0+k1ofxcMnuHT4AA5b6SOU9U4EUFEyqrqTndNCFPQwr932h6u++cFX8pzzv3z/fXTi45LIkX9Cal+PX+NXcSY4c8j1W1+nkJryXjn3x7j/9zX6nb4aSIseRYa3whlcjkqO/EPp/qjbgenWrNUNt8zU5Jh8TPOF5mC6NuiCnGn4Yrr4LYp+d6Q61P+5eG2j2HRU/DjO86+656Hzg9clNJfTgNElDuD65fAYhE5Rcb1pU1B+Hk6lAuERjfm+RLp59yvWbksN7Sohb+XfvoB5fwZ0DaYkLJt4X9tnf/4g2dcyBMYX9m/DrbOhr/8A6p4BPFSpaDXKzC5N6z5H3R9LHfXXfu20+YVscpp/7p5AvhnMuVJQix88VfYOd/5JhxQQL2nAutCx7FpOlYUGaVKQa+XoHaY83+94cUbfpbTRur+7svxIrIcCAQW+ixXJmf+OOWMfWhzR+b/QbNw6MwfTFkTwafr9nM2LolWwYG8OdjpH5/9gLCKcPXDsPQ52Pc9XHZN3p7B+EZKilMtEVALujyYMb1+Z2h6M6x+A1oPg8A6Obvu2UOw6r/QuI9Tglj8jNO+MfiTjP32Y445degHNkKvf0HHey70qUq2lgMv+i1z3UldVb9X1a9VNSG7Y0Wkl4jsEpE9IvK4l/RAEZknIr+IyDYRGeWRNklEjorI1tzmscTYOgeS453/4Lm0Zu9xev53JR+s3MfVDWow595OfHlfF/qF1cn5aOGO90FgPfjuSacawRQeW2Y5H8zdn828SuW6fzp/t6W5qJ5c9jykJELP553AM2CSc5+PejrdM887vgc+6gFHtsKg6RYciiifjWISET+c2V97A02BISLSNN1h9wHbVbUV0BV4TUTOz1s7Bejlq/wVCz/PgJrNoVarXJ325c8HGDHpJ2pWLseyv3flnaFtaFs/D5O++ZeDns85HwKbpubuXOM7CeectofabZwxD5mpGgKd7oNfP4OoHIwfOrAJNs+Ajvc6XTEBmt/qDJw8dww+7OEEi/3r4KPrID4aRsyHJn3y46lMAfBlhVwHYI+q7gMQkZlAP2C7xzEKBIjzyVQJOAkkAajqSnfEdo7tOrGLrlO6ptk3sNlAxrYfS2xiLDfMuCHDOcNa3IH80Y2QGsk8v/auDOn3truXQc0HEXkmkuFzh2dI/3unv9O3UV92Hd/F3fPvzpD+1F+eosdlPdh8eDPjFo7LkP5S95foXLczayLX8OTSJzOkv9HrDcIuDWPJviW8sPKFPxMSYuHgJt6/+ikaiTBv1zxeW/tahvOn9Z9G3cC6fLb1MyZsmMCB038QeTKWypX8iasSQKUKc4CKTNk8hSmbp2Q4f8HQBVTwr8C7699l1rZZGdJXjFgO9Trz6nePMP+HF9Kklfcrzbct7wTg+YglLD21N0169Sr1mDNyOQBPLHmCtVFr06QHVw5m+i3TARi3cBybD29Ok96wekMm9nUGfI2ZN4bfTvyWJj3s0jDe6PUGAMO+GEbU2bSjizsFd+LlHi8DcOusWzkReyJNevfQ7jx9zdMA9J7Rmz/STcnQp2EfHun8CECG9x2xJxnYpD9ju/0z0/feyLCRjAwbyfHY4wyYNSBDep7fe6d+h+hInupyHz1Klcr6vXf1w6zZ+CFPTrsOLm2ZpuEzw3vv0K/glwCRy2FKV97v8z6NghoxL+4Er1W/1Pmi8KE7DUvpskwb9i1167ZPfe+lN3vgbIIqBOX9vTdyBQCvrnmV+b/NT5NW3r883w79FoDnv3+epeFL06RXr1CdOQPnAMXwvUf2n3ue772s+DJA1AEiPbajgCvTHfM28DVOg3cAMEhVU3JzExEZgzOAj7J1Mp+kLDPJKcqklXupWikOitKU9zFHnP/MDXNWyEpOSWHf8XMcPRtHUKWyXFajIqXyoxeECPR+BSZ1g9O/Z0xf/qL7Ih439v/pTCRsmAztRqU/q2g7FQ5nDsC503D1/13ce5/e7/xeK12Ss66cZQOg/V9h5XNwdDvUaAylvMwKe+44xJ+F6ld4T/cv7wzaOrrDeU/UaOzM22WKNlX1yQ9wG/Chx/Zw4H/pjhkA/BcQ4AogHKjskR4CbM3pPdu2bat5MWdjpNZ/bL7O2RiZp/MvuqQE1X9dpjpzWI4Oj45L1Ds+Wqf1H5uv/164Q5OTU/I/T8nJqslJOf/547TqtFtVn62suuSfqik+yNPFlvCH6md3OM809Wbn3zVvX5x7JyWozh3r3POLu1UT43N3/obJquOrqk7oonrmYNq0hFjV15upvtvF+dtlJSWlePwtSxBgg2bymerLmdSiAM8O8sFk7Bo7CvjCzeceN0A09mGevLo5rA6tggP518KdxCYkZX9CAZr3y0HemfgOxB4nudXQLI9NTlEWbj3Ere+u4Yc9x3mpfwsevb5xvqzHkEGpUs43y5z+lAuEITOdHlirXnO6QibFZ3+fwir2JEztB9u/dPqpD/sCLu8OK/4F505ke/oFiTvrjEvYPB2ueczpdlo6l0tQth3pTNlwMtxpSzi648+0tW87pZJeL3svPXgSKVmjs4s5XwaI9UADEQl1G54H41QnedoPdAcQkZpAI2CfD/PkValSwjN9m3LkbDzvrdib/QkFQFV5d8UeHvj0Z5oc+pojWoXrvi7N5NXhxMSnDWpn4xL5cNU+rvnPcu6ZvolzCUl8OKIdt19ZyOZI8isNfd+Ca5+GLZ/D9FudrrtFzclwp1H24CYYMBm6/M35kLz+JUiIgRUv+e7eZw864xnCV8JNb0O3J/P+Ad3gOhi1wOml9NH1zjXPd2tt0hdCr87fvJtCz6cryonIDcAbgB8wSVVfFJF7AFT1PRGpjdNbqRZONdMrqjrdPfdTnJ5NQcAR4FlV/Sir+13obK4PfPozi7YdZtkjXalTJfslJfNFchIkxmZ5SFJKCi8u2MnnGyIZ2LQCT4cPZ2+D0Tx25pY0y1b2an4p3/x6KHWVtQ6h1RjdJZTrmtYs/CuG/fIZfHWf0ztm8Cc+m3ws3x3dDjOHQkoSDPk048ygCx6F9R/CPauhZvpOfDmUGAfJXnqVn9zr3DvuDAz82JnuOT+c3u/OdroXLm3hND7ft+7PnkumWLElR3PowOk/uPbVFVzf7FLeGnIR1kI6vBU+HQJn9uf+3Ps3QFCDNGsVJ6Uo/n7OOs2ju4TSvE5g/ufZl8JXwsxhEO99mo9Cq0p9Z+7+oAYZ02JPwlthTpfT4XNz/+1+3UR3nEmi9/SAWnD7LKjVMtfZzpLnegldHoTrnsvf65tCwwJELry+aBdvLdvDnHs70bZ+Dld0you9y+CzO5xeJB3vBclY2xcdn8Rn6/dz5GwcvZrXom29qk5ClboZpv89fCaO1XuOc3XDIC4JyP2o6kLjxF74baEzf05R4OcPzW6BSjUyP+bHCc7sqUM+g0Y5HNqTkgKLn3bq/xv0hFAvI9VL+Tnvg8q185b37CTFw85voNENeRqpb4oGCxC5cC4+iWtfW8GlgeWZe29nrw26B0//wc/7T6O5mHjMT4ROl1enSoUyzgC3eX+DoEYw9HOv0xxsPXCGu6dt5FRsAu/c3oZujYtIlYvJKDkR3u0EKNy7NvsG5MQ4Z3XA7V9Bh7tz1jhsTB7lx5KjJUbFsqX5x/WN+fvnv/Dl5gPc0ubPKbQ37T/FpB/C+XbrYZJTch9Yy/kLb9deTI8jk5wlOwdOdXrzuFJSlO93H2PSD+Gs2n2cGgFl+WxMJ1oEF7GqIpOWn7/TYP3JbU57RKexmR8be9Kpdoxc55zTcaz1CjIFxgKEF/1b12Hq2gj+tXAn3ZvUdKbA/iGczZGnCShXmjuvCuWmVrUpm4v1ls/GxpLy1TjaH1nA7OS/8E3iPxjxezx/aaDEJSUzZ9MBJq8OZ9+xc1wSUJZHr2/E7R3qUbViLrsrmsKpwXVOt9fvX3Gmv6hYPeMxJ/fB9AFwJsqZljqPi9Abk1+siikTG38/ya0T1lLe348/EpMJDarIqC4h3NommIplcxlX4846y3TuXUZsp0f4yG8QU9ft51h0PJcFVeR4TDxn45JoGRzInVeF0rt5LcrkIviYIuLoTpjQ2Vn6M8jL+sG/LQRNcXpD1et48fNnSiRrg8ijF+ZvZ/fRGEZ0rk/XhpfkbYDZmQPwyUA4thP6vpk682pCUgrfbDnIpz9FUqNSWUZfFUKbelVzP2GeKVpWv+n0TPKmci24+T0IuuLi5smUaBYgCsrhrU5/8vhot59694LOkTHGpGGN1AVh73KYdQeUqQSjv3UGHBljTBFiFd2+8PMMmDHAWebwriUWHIwxRZKVIPKTKnz/L1jxstdurMYYU5RYgMgvyYkwb5wzo2ar250G6dzOqGmMMYWIBYj8EHfWaW/Yt9yZbrnrEza4yRhT5FmAuFCe3Vj7vZPajdUYY4o6CxAXwrMb6+2zrBurMaZYsQCRV6mzsVo3VmNM8WQBIjMpKbDyP858+OmpQuSP7myssyAwOOMxxhhTxFmA8CbxD/hiDOz4Gmq3Bv8KGY9pOciZhtm6sRpjiikLEOmdOwEzh0DkT3D9y1lPzWyMMcWYT0dSi0gvEdklIntE5HEv6YEiMk9EfhGRbSIyKqfn+sTJfc7i84d+ceZOsuBgjCnBfFaCEBE/4B3gOiAKWC8iX6vqdo/D7gO2q2pfEakB7BKRGUByDs7NX1EbnO6qqnDH11DvSp/dyhhjigJfliA6AHtUdZ+qJgAzgX7pjlEgQJw5risBJ4GkHJ6bf3bMhyl9oGxlZ+4kCw7GGOPTAFEHiPTYjnL3eXobaAIcBLYAD6pqSg7PBUBExojIBhHZcOzYsdznMvYkzL0HajaDOxdD9ctzfw1jjCmGfNlI7W2uifSLT1wPbAauBS4HFovIqhye6+xUnQhMBGc9iFznskI1GD7XCRBlvPRWMsaYEsqXJYgooK7HdjBOScHTKOALdewBwoHGOTw3/9Rtb8HBGGPS8WWAWA80EJFQESkDDAa+TnfMfqA7gIjUBBoB+3J4rjHGGB/yWRWTqiaJyP3Ad4AfMElVt4nIPW76e8DzwBQR2YJTrfSYqh4H8Haur/JqjDEmI1uT2hhjSrCs1qS2JUeNMcZ4ZQHCGGOMVxYgjDHGeGUBwhhjjFcWIIwxxnhlAcIYY4xXFiCMMcZ4ZQHCGGOMVxYgjDHGeGUBwhhjjFcWIIwxxnhlAcIYY4xXFiCMMcZ4ZQHCGGOMVxYgjDHGeGUBwhhjjFcWIIwxxnhlAcIYY4xXPg0QItJLRHaJyB4RedxL+qMistn92SoiySJSzU170N23TUTG+TKfxhhjMvJZgBARP+AdoDfQFBgiIk09j1HV/6hqmKqGAU8A36vqSRFpDvwV6AC0AvqISANf5dUYY0xGvixBdAD2qOo+VU0AZgL9sjh+CPCp+7oJ8KOqxqpqEvA90N+HeTXGGJOOLwNEHSDSYzvK3ZeBiFQAegFz3F1bgb+ISHU37Qagrg/zaowxJp3SPry2eNmnmRzbF1itqicBVHWHiPwLWAzEAL8ASV5vIjIGGANQr169C82zMcYYly9LEFGk/dYfDBzM5NjB/Fm9BICqfqSqbVT1L8BJYLe3E1V1oqq2U9V2NWrUyIdsG2OMAd8GiPVAAxEJFZEyOEHg6/QHiUggcA3wVbr9l7j/1gNuIV0AMcYY41s+q2JS1SQRuR/4DvADJqnqNhG5x01/zz20P7BIVc+lu8QcEakOJAL3qeopX+XVGGNMRqKaWbNA0dOuXTvdsGFDQWfDGGOKDBHZqKrtvKXZSGpjjDFeWYAwxhjjlQUIY4wxXlmAMMYY45UFCGOMMV5ZgDDGGOOVBQhjjDFeWYAwxhjjlQUIY4wxXlmAMMYY45UFCGOMMV5ZgDDGGOOVBQhjjDFeWYAwxhjjlQUIY4wxXlmAMMYY45UFCGOMMV5ZgDDGGOOVBQhjjDFe+TRAiEgvEdklIntE5HEv6Y+KyGb3Z6uIJItINTftIRHZ5u7/VETK+TKvxhhj0vJZgBARP+AdoDfQFBgiIk09j1HV/6hqmKqGAU8A36vqSRGpA/wNaKeqzQE/YLCv8mqMMSYjX5YgOgB7VHWfqiYAM4F+WRw/BPjUY7s0UF5ESgMVgIM+y6kxxpgMSvvw2nWASI/tKOBKbweKSAWgF3A/gKoeEJFXgf3AH8AiVV2UybljgDHuZoyI7MpjfoOA43k8tyiz5y5Z7LlLlpw8d/3MEnwZIMTLPs3k2L7AalU9CSAiVXFKG6HAaeBzERmmqtMzXFB1IjDxgjMrskFV213odYoae+6SxZ67ZLnQ5/ZlFVMUUNdjO5jMq4kGk7Z6qQcQrqrHVDUR+ALo7JNcGmOM8cqXAWI90EBEQkWkDE4Q+Dr9QSISCFwDfOWxez/QUUQqiIgA3YEdPsyrMcaYdHxWxaSqSSJyP/AdTi+kSaq6TUTucdPfcw/tj9PGcM7j3HUiMhvYBCQBP5MP1UjZ8PX1Cyt77pLFnrtkuaDnFtXMmgWMMcaUZDaS2hhjjFcWIIwxxnhV4gNEdtOBFCciMklEjorIVo991URksYjsdv+tWpB5zG8iUldElovIDnfqlgfd/cX9ucuJyE8i8ov73P909xfr5z5PRPxE5GcRme9ul5TnjhCRLe70RRvcfXl+9hIdIHIyHUgxMwVnQKKnx4GlqtoAWOpuFydJwN9VtQnQEbjP/RsX9+eOB65V1VZAGNBLRDpS/J/7vAdJ2/OxpDw3QDd3CqPz4x/y/OwlOkCQ++lAijRVXQmcTLe7H/Cx+/pj4OaLmSdfU9VDqrrJfR2N86FRh+L/3KqqMe6mv/ujFPPnBhCRYOBG4EOP3cX+ubOQ52cv6QHC23QgdQooLwWlpqoeAufDFLikgPPjMyISArQG1lECntutZtkMHAUWq2qJeG7gDeAfQIrHvpLw3OB8CVgkIhvdaYjgAp7dl1NtFAW5mQ7EFGEiUgmYA4xT1bPO+MviTVWTgTARqQLMFZHmBZwlnxORPsBRVd0oIl0LODsFoYuqHhSRS4DFIrLzQi5W0ksQuZkOpLg6IiK1ANx/jxZwfvKdiPjjBIcZqvqFu7vYP/d5qnoaWIHT/lTcn7sLcJOIROBUGV8rItMp/s8NgKoedP89CszFqUbP87OX9ACRo+lAirmvgRHu6xGknfKkyHOnavkI2KGqr3skFffnruGWHBCR8jjzm+2kmD+3qj6hqsGqGoLz/3mZqg6jmD83gIhUFJGA86+BnsBWLuDZS/xIahG5AafO8vx0IC8WbI58R0Q+BbriTAF8BHgW+BKYBdTDmQPrtvOz6hYHInIVsArYwp910k/itEMU5+duidMg6YfzRXCWqj4nItUpxs/tya1iekRV+5SE5xaRy3BKDeA0H3yiqi9eyLOX+ABhjDHGu5JexWSMMSYTFiCMMcZ4ZQHCGGOMVxYgjDHGeGUBwhhjjFcWIEyxICIrRMTni9KLyN/cmWFn5PH8KSIyIL/zlV9EpKuI5Hr9dxEJ8Zwl2BQPJX2qDWMQkdKqmpTDw8cCvVU13Jd5KggiUhpnnEwMsCYX5/n5Kk+mYFkJwlw07rfMHSLygbtGwSJ3lG+aEoCIBLlTJSAiI0XkSxGZJyLhInK/iDzszvX/o4hU87jFMBFZIyJbRaSDe35FcdbBWO+e08/jup+LyDxgkZe8PuxeZ6uIjHP3vQdcBnwtIg+lO95PRP7j3udXEbnb3S8i8raIbBeRb/CYKE1EbhCRnSLyg4i8JX+uXZBZnpuJs8bDZvceDbzkO0ZEXhORTSKyVERquPsvF5GF7iRuq0Sksbt/ioi8LiLLgc+Ae4CH3Htcnb7EIyIx7r9dxVln4xOcQYgApUXkYzdvs0WkQnbvCVPIqar92M9F+QFCcNZnCHO3ZwHD3NcrgHbu6yAgwn09EtgDBAA1gDPAPW7af3Em3zt//gfu678AW93XL3ncowrwG1DRvW4UUM1LPtvifOhVBCoB24DWbloEEOTlnDHAU+7rssAGIBS4BViMM6K5NnAaGACUw5lJONQ951NgfjZ5/h8w1N1fBijvJR/qccwzwNvu66VAA/f1lThTUICzRsh8wM/dHo8z+hiP9AEe2zHuv12Bcx75D3Hv3cXdnuR5Hfspmj9WgjAXW7iqbnZfb8T5YMnOclWNVtVjOAFinrt/S7rzP4XUdS8qu3MR9QQeF2fa6xU4H8z13OMXq/cpB64C5qrqOXXWVPgCuDqbPPYE7nDvsw6oDjTACVafqmqyOhOpLXOPbwzs0z+rqj5Ndy1veV4LPCkijwH1VfUPL/lIwSkJAEwHrhJnJtvOwOfuNd8Hanmc87k6M7/m1k+atqotUlVXe947D9c0hYi1QZiLLd7jdTJQ3n2dxJ9VnuWyOCfFYzuFtO/h9PPGKM6U7req6i7PBBG5EucbsDd5mQtcgAdU9bt097nBS76yu4fXPAM7RGQdzmI434nIXaq6LOPpaSjO7/W0qoZlckxmvwfw+LuIiOCUXDI7z9vv3xRhVoIwhUUETtUOOFUweTEIUifoO6OqZ4DvgAfcDzdEpHUOrrMSuFlEKogzK2Z/nAn/svIdcK84U4sjIg3dc1cCg902ilpAN/f4ncBl4ixilJp3j2tlyLM4k7HtU9W3cGbobOklH6X48/d3O/CDqp4FwkXkNvc6IiKtMnmOaJzqvPMi+PPv0g9nZbrM1BORTu7rIcAPWRxrigALEKaweBXnA3YNThtEXpxyz38PuNPd9zzOh9qv4nTDfD67i6izROkU4Cec6qIPVfXnbE77ENgObHLv8z5O6WYusBunOmwC8L17jz9wekQtFJEfcGbXPZNNngcBW91qosbAVC/5OAc0E5GNwLXAc+7+ocCdIvILTptKZkvrzgP6n2+kBj4ArhGRn3DaLrIqbewARojIr0A193lNEWazuRpTQESkkqrGuCWFd4DdqvrfC7xmjKpWyp8cmpLOShDGFJy/uqWBbUAgTqnDmELDShDGGGO8shKEMcYYryxAGGOM8coChDHGGK8sQBhjjPHKAoQxxhiv/h8+Idme7DJX0wAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(range(num), acc_cora_augment[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora_augment[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.78, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "61973caa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8149999999999998\n",
      "0.0037225183487986347\n"
     ]
    }
   ],
   "source": [
    "index_cora_augment = np.where(acc2_cora_augment == max(acc2_cora_augment))\n",
    "print(np.array(acc_cora_augment)[index_cora_augment].mean())\n",
    "print(np.array(acc_cora_augment)[index_cora_augment].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "83f6b242",
   "metadata": {},
   "outputs": [],
   "source": [
    "down_weight = 0.1\n",
    "num = 50\n",
    "threshold = 0.00005\n",
    "acc_pubmed_augment = []\n",
    "acc2_pubmed_augment = []\n",
    "\n",
    "\n",
    "pubmed_infl_0 = pd.read_csv('result_data/pubmed_edge_influence.csv', header = None)\n",
    "pubmed_infl_0 = pubmed_infl_0.loc[abs(pubmed_infl_0[1]) < 0.00005]\n",
    "pubmed_infl_0 = pubmed_infl_0.sort_values([1])\n",
    "pubmed_infl_0.index = range(len(pubmed_infl_0))\n",
    "\n",
    "from_index_pubmed_less_infl = pubmed_infl_0.loc[0:][2].values.astype(int)\n",
    "to_index_pubmed_less_infl = pubmed_infl_0.loc[0:][3].values.astype(int)\n",
    "nis_pubmed_less_infl = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                   from_index=from_index_pubmed_less_infl, to_index=to_index_pubmed_less_infl)\n",
    "nis_pubmed_less_infl.remove_edges_sgc_from_influence()\n",
    "feat_augment_pubmed = nis_pubmed_less_infl.calculate_modified_features()\n",
    "\n",
    "train_x_pubmed_augment_low_infl = feat_augment_pubmed[train_mask_pubmed == 1].numpy()\n",
    "index_augment = np.unique(np.where(train_x_pubmed != train_x_pubmed_augment_low_infl)[0])\n",
    "train_x_pubmed_extra = train_x_pubmed_augment_low_infl[index_augment]\n",
    "train_y_pubmed_extra = train_y_pubmed[index_augment]\n",
    "\n",
    "w1 = np.ones(train_x_pubmed_extra.shape[0] + train_x_pubmed.shape[0])\n",
    "w1[len(train_x_pubmed):] = down_weight\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "e68c8d3c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:03<00:00, 16.16it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(num)):\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i][3].values.astype(int)\n",
    "    \n",
    "\n",
    "    \n",
    "    nis_pubmed = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                           from_index=from_index_pubmed, to_index=to_index_pubmed)\n",
    "    nis_pubmed.remove_edges_sgc_from_influence()\n",
    "    feat_removed_pubmed = nis_pubmed.calculate_modified_features()\n",
    "    \n",
    "    train_x_pubmed_remove_high_infl = feat_removed_pubmed[train_mask_pubmed == 1].numpy()\n",
    "    \n",
    "    \n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    \n",
    "    train_x_pubmed_new = np.concatenate([train_x_pubmed_remove_high_infl, train_x_pubmed_extra])\n",
    "    train_y_pubmed_new = np.concatenate([train_y_pubmed, train_y_pubmed_extra])\n",
    "    \n",
    "    lr_pubmed.fit(train_x_pubmed_new, train_y_pubmed_new, sample_weight=w1, verbose=False)\n",
    "    acc_pubmed_augment.append(np.mean(lr_pubmed.model.predict(test_x_pubmed) == test_y_pubmed))\n",
    "    acc2_pubmed_augment.append(np.mean(lr_pubmed.model.predict(val_x_pubmed) == val_y_pubmed))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "3e9a3b59",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(range(num), acc_pubmed_augment[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed_augment[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.75, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "16ffb9f4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.782\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "index_pubmed_augment = np.where(acc2_pubmed_augment == max(acc2_pubmed_augment))\n",
    "print(np.array(acc_pubmed_augment)[index_pubmed_augment].mean())\n",
    "print(np.array(acc_pubmed_augment)[index_pubmed_augment].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cab0f138",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
