{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "00b37014",
   "metadata": {},
   "outputs": [],
   "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": 28,
   "id": "f19a85bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.01\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": 29,
   "id": "074212ff",
   "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": 30,
   "id": "96904b81",
   "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": 31,
   "id": "12d6b1fa",
   "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": 32,
   "id": "288ca3e3",
   "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[0] > 0]\n",
    "cora_infl = cora_infl.sort_values([1], ascending=False)\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "281f682f",
   "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], ascending=False)\n",
    "pubmed_infl.index = range(len(pubmed_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "48996b48",
   "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], ascending=False)\n",
    "citeseer_infl.index = range(len(citeseer_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "1ac72c89",
   "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": 36,
   "id": "5144a4cf",
   "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>2.697631</td>\n",
       "      <td>1.777291</td>\n",
       "      <td>2014.0</td>\n",
       "      <td>1281.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          0         1       2       3\n",
       "0  2.697631  1.777291  2014.0  1281.0"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl.loc[0:0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "8a6a3457",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [00:40<00:00,  2.47it/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": 38,
   "id": "87163995",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEWCAYAAAB8LwAVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABHUklEQVR4nO3dd3hU1dbA4d9KIyRAKAEEAiZIrwFBpKgIiICADQUEFNSLyhVFxQ9Rr3qv9dquHQFFFLEgVhAQaYKiSJWOlICE3hIIJXV9f5whpkxCEmYyKet9nnmYc/Yp+yTDrOx9zl5bVBVjjDEmKz9fV8AYY0zRZAHCGGOMWxYgjDHGuGUBwhhjjFsWIIwxxrhlAcIYY4xbFiCMMca4ZQHCGGOMWxYgjPEBEQnwdR2MORcLEMYUgIjUFpGvROSQiBwRkbdExE9EHheRXSJyUEQ+EpEw1/aRIqIicoeI/AUscK3/QkT2i0i8iCwWkaY+vTBjMrAAYUw+iYg/MBPYBUQCtYDPgKGu15VAXaAc8FaW3a8AGgNXu5ZnA/WBasAqYKo3625MfojlYjImf0SkPfAdUENVUzKsnw98qarvuJYbAuuBskAEEANcpKo7cjhuReAYUFFV4716EcbkgbUgjMm/2sCujMHBpSZOq+KsXUAAUD3Dut1n34iIv4i8ICLbReQ4sNNVFO75KhuTfxYgjMm/3UAdNzea9wIXZliuA6QABzKsy9hkvwW4FugGhOF0VwGIJytrTEFZgDAm/34H9gEviEioiASLSEfgU+ABEYkSkXLAc8DnbloaZ5UHEoEjQIhre2OKDAsQxuSTqqYCfYB6wF9ALNAfmARMARbj3G84A4zM5VAf4XRD7QE2Ar95r9bG5J/dpDbGGOOWtSCMMca45dUAISI9RGSLiGwTkUfclIeJyAwR+UNENojIsAxlFUVkuohsFpFNrkcLjTHGFBKvdTG5BhP9CVyF00e7HBioqhszbPMoEKaqY0SkKrAFuEBVk0TkQ2CJqr4nIkFAiKrGeaWyxhhjsvFmC+ISYJuq7lDVJJyRptdm2UaB8iIiOKNOjwIpIlIBuBx4H0BVkyw4GGNM4fJmwrBaZBgUhNOKaJdlm7dwRqTuxXnkr7+qpolIXeAQ8IGItARWAver6smsJxGR4cBwgNDQ0IsbNWrk8QsxxpiSauXKlYdVtaq7Mm8GCHeDfbL2Z10NrAG6ABcBP4rIEle9WgMjVXWZiLwOPAL8K9sBVScAEwDatGmjK1as8NgFGGNMSSciu3Iq82YXUyxOSoKzInBaChkNA75SxzacZ8cbufaNVdVlru2m4wQMY4wxhcSbAWI5UN81qjQIGIDTnZTRX0BXABGpDjQEdqjqfmC3K9kZrm02YowxptB4rYtJVVNE5F7gB8AfmKSqG0Tkblf5u8DTwGQRWYfTJTVGVQ+7DjESmOoKLjtwWhvGGGMKSYkaSe3uHkRycjKxsbGcOXPGR7Uy7gQHBxMREUFgYKCvq2JMqSYiK1W1jbuyEj/tYWxsLOXLlycyMhLnaVrja6rKkSNHiI2NJSoqytfVMcbkoMSn2jhz5gxVqlSx4FCEiAhVqlSxVp0xRVyJDxCABYciyH4nxhR9pSJAGGOMyT8LEF4WFxfHO++8U+D9X3vtNU6dOuXBGhljTN5YgPCykhAgUlJymhDNGFOSWYDwskceeYTt27cTHR3Nww8/DMBLL71E27ZtadGiBU8++SQAJ0+e5JprrqFly5Y0a9aMzz//nDfeeIO9e/dy5ZVXcuWVV2Y79n/+8x/atm1Ls2bNGD58OGcfWd62bRvdunWjZcuWtG7dmu3btwPw4osv0rx5c1q2bMkjjzjZ1zt37szZR4MPHz5MZGQkAJMnT+amm26iT58+dO/enYSEBLp27Urr1q1p3rw53377bXo9PvroI1q0aEHLli0ZMmQIJ06cICoqiuTkZACOHz9OZGRk+rIxpngo8Y+5ZvTvGRvYuPe4R4/ZpGYFnuzTNMfyF154gfXr17NmzRoA5s6dy9atW/n9999RVfr27cvixYs5dOgQNWvW5PvvvwcgPj6esLAwXn31VRYuXEh4eHi2Y99777088cQTAAwZMoSZM2fSp08fBg0axCOPPML111/PmTNnSEtLY/bs2XzzzTcsW7aMkJAQjh49es5r+/XXX1m7di2VK1cmJSWFr7/+mgoVKnD48GEuvfRS+vbty8aNG3n22Wf55ZdfCA8P5+jRo5QvX57OnTvz/fffc9111/HZZ59x44032pgHY4oZa0EUsrlz5zJ37lxatWpF69at2bx5M1u3bqV58+bMmzePMWPGsGTJEsLCws55rIULF9KuXTuaN2/OggUL2LBhAydOnGDPnj1cf/31gDMgLSQkhHnz5jFs2DBCQkIAqFy58jmPf9VVV6Vvp6o8+uijtGjRgm7durFnzx4OHDjAggUL6NevX3oAO7v9nXfeyQcffADABx98wLBhNhDemOKmVLUgcvtLv7CoKmPHjuWuu+7KVrZy5UpmzZrF2LFj6d69e3rrwJ0zZ84wYsQIVqxYQe3atXnqqac4c+YMOY2MV1W3j5YGBASQlpaWfsyMQkND099PnTqVQ4cOsXLlSgIDA4mMjEw/n7vjduzYkZ07d/LTTz+RmppKs2bNcrwWY0zRZC0ILytfvjwnTpxIX7766quZNGkSCQkJAOzZs4eDBw+yd+9eQkJCGDx4MKNHj2bVqlVu9z/r7Jd5eHg4CQkJTJ8+HYAKFSoQERHBN998A0BiYiKnTp2ie/fuTJo0Kf2G99kupsjISFauXAmQfgx34uPjqVatGoGBgSxcuJBdu5wMwV27dmXatGkcOXIk03EBbr31VgYOHGitB2OKqVLVgvCFKlWq0LFjR5o1a0bPnj156aWX2LRpE+3bO1NslytXjo8//pht27bx8MMP4+fnR2BgIOPGjQNg+PDh9OzZkxo1arBw4cL041asWJF//OMfNG/enMjISNq2bZteNmXKFO666y6eeOIJAgMD+eKLL+jRowdr1qyhTZs2BAUF0atXL5577jlGjx7NzTffzJQpU+jSpUuO1zFo0CD69OlDmzZtiI6O5uzETE2bNuWxxx7jiiuuwN/fn1atWjF58uT0fR5//HEGDhzo6R+rMaYQlPhkfZs2baJx48Y+qlHpNn36dL799lumTJnittx+N8b4XqlO1md8Y+TIkcyePZtZs2b5uirGmAKyAGG84s033/R1FYwx58luUhtjjHHLAoQxxhi3LEAYY4xxy6sBQkR6iMgWEdkmIo+4KQ8TkRki8oeIbBCRYVnK/UVktYjM9GY9jTHGZOe1ACEi/sDbQE+gCTBQRJpk2eyfwEZVbQl0Bl4RkaAM5fcDm7xVR2OMMTnzZgviEmCbqu5Q1STgM+DaLNsoUF6cXA3lgKNACoCIRADXAO95sY5FTrly5XxdBWOMAbwbIGoBuzMsx7rWZfQW0BjYC6wD7lfVNFfZa8D/AWmYQmdzQBhjvDkOwt2kw1mHbV8NrAG6ABcBP4rIEuBy4KCqrhSRzrmeRGQ4MBygTp06uddo9iOwf925a54fFzSHni/kWDxmzBguvPBCRowYAcBTTz2FiLB48WKOHTtGcnIyzzzzDNdem7VxlV1CQgLXXnut2/0++ugjXn75ZUSEFi1aMGXKFA4cOMDdd9/Njh07ABg3bhw1a9akd+/erF+/HoCXX36ZhIQEnnrqKTp37kyHDh345Zdf6Nu3Lw0aNOCZZ54hKSmJKlWqMHXqVKpXr05CQgIjR45kxYoViAhPPvkkcXFxrF+/nv/9738ATJw4kU2bNvHqq6+e14/XGOM73gwQsUDtDMsROC2FjIYBL6iT72ObiMQAjYCOQF8R6QUEAxVE5GNVHZz1JKo6AZgATqoNz1/G+RkwYACjRo1KDxDTpk1jzpw5PPDAA9nmVnCXFTWj4ODgPM/JAHDfffdxxRVX8PXXX5OamkpCQgLHjh3L9RxxcXH89NNPABw7dozffvsNEeG9997jxRdf5JVXXuHpp58mLCyMdevWpW8XFBREixYtePHFFwkMDOSDDz5g/Pjx5/vjM8b4kDcDxHKgvohEAXuAAcAtWbb5C+gKLBGR6kBDYIeqjgXGArhaEKPdBYd8y+UvfW9p1apVerbWQ4cOUalSJWrUqMEDDzzA4sWL8fPzS59b4YILLsj1WGfnZMi6X05zMixYsICPPvoIAH9/f8LCws4ZIPr375/+PjY2lv79+7Nv3z6SkpKIiooCYN68eXz22Wfp21WqVAmALl26MHPmTBo3bkxycjLNmzfP50/LGFOUeC1AqGqKiNwL/AD4A5NUdYOI3O0qfxd4GpgsIutwuqTGqOphb9XJV/r168f06dPZv38/AwYMyHFuhXPJ75wM7mSc/wFynwNi5MiRPPjgg/Tt25dFixbx1FNPATnPLXHnnXfy3HPP0ahRI0vxbUwJ4NVxEKo6S1UbqOpFqvqsa927ruCAqu5V1e6q2lxVm6nqx26OsUhVe3uznt42YMAAPvvsM6ZPn06/fv1ynFvhXPI7J0PXrl3T04anpqZy/PhxqlevzsGDBzly5AiJiYnMnJnzEJP4+Hhq1XKeK/jwww/T13fv3p233norfflsq6Rdu3bs3r2bTz75xFJ8G1MC2EjqQtC0aVNOnDhBrVq1qFGjBoMGDWLFihW0adOGqVOnps+tcC457ZdxToaWLVvy4IMPAvD666+zcOFCmjdvzsUXX8yGDRsIDAzkiSeeoF27dvTu3TvXcz/11FPcdNNNXHbZZZnmxH788cc5duwYzZo1o2XLlpnmqbj55pvp2LFjereTMab4svkgjEf17t2bBx54gK5du55zW/vdGON7uc0HYS0I4xFxcXE0aNCAsmXL5ik4GGOKPpsPoghat24dQ4YMybSuTJkyLFu2zEc1OreKFSvy559/+roaxhgPsgBRBDVv3pw1a9b4uhrGmFLOupiMMca4ZQHCGGOMWyWri2nLFujcOfO6F190/k1NhW3bsu9TpQqEh0NyMrhyFmVStSpUrgxJSRATk728enWoWBHOnAF34xlq1IAKFeDUKdi9O3t5rVpQrhwkJMCePdnLa9eGkBA4fhz27ctefuGFEBwMcXFw4ED28qgoCAqCo0fh0KHs5XXrQmAgHD4MrnEUmdSrB/7+cPAguBuF3bCh8+/+/RAfn7lMBBo0cN7v3QsnTmQuP3QIzj7FNHYs/Ppr5vKICPjYNTRm1CjI2u3WoAFMmOC8Hz4cst4DiY6G115z3g8eDLGxmcvbt4fnn3fe33hj9uvv2hX+9S/nfc+ecPp05vLevWH0aOd91s8dwM03w4gRzu++V6/s5UOHOq/Dh6Ffv+zl99wD/fs7n5ss96QAeOgh6NPH+dzfdVf28scfh27dnJ/bqFHZy597Djp0gKVL4dFHs5e/9przM5w3D555Jnv5+PHO73/GDHjllezlU6Y4n9/PPwfXeJxMpk93/u9Nnuy8spo1y/nsv/MOTJuWvXzRIuffl1+GrON5ypaF2bOd908/DfPnZy6vUgW+/NJ5X9o/e7mwFkQhePbZZ2napg0t+vYl+rrrWPbHH6SkpPDoq69SPzqa6Ohoojt04Nl3303fZ/+hQwx48EEuataMJk2a0KtfP/50F6CMMcZbVLXEvC6++GLNauPGjdnWFaalS5fqpZdeqmfOnFFV1UOHDumePXt0zJgxetttt+np06dVVfX48eP65JNPqqpqWlqaXnrppTpu3Lj046xevVoXL15c6PX3Jl//bowxqsAKzeE7tWR1MRVB+/btIzw8nDJlygAQHh7OqVOnmDhxIjt37iQ4OBiA8uXLp+c6WrhwIYGBgdx9993px4mOji7sqhtjSrlSFyA6T+6cbd3NTW9mRNsRnEo+Ra+p2fvrhkYPZWj0UA6fOky/aZn7ihcNXZTr+bp3785//vMfGjRoQLdu3ejfvz+VKlWiTp06lC9f3u0+69ev5+KLL87zNRljjDfYPQgvK1euHCtXrmTChAlUrVqV/v37s+jszTWXDz74gOjoaGrXrs1udzeyjTHGBywXUyGbPn0648ePZ9WqVezcuTNTK6JZs2bMnDmT7du38+9//5vFixf7sKbeV9R+N8aURpaLyYe2bNnC1q1b05fXrFlDw4YNueOOO7j33nvT52NITU0lKSkJcCbeSUxMZOLEien7LV++PH2mN2OMKQyl7h5EYTs7f3NcXBwBAQHUq1ePCRMmEBYWxr/+9S+aNWtG+fLlKVu2LLfddhs1a9ZERPj6668ZNWoUL7zwAsHBwURGRvLa2eeqjTGmEFgXk/EZ+90Y43vWxWSMMSbfLEAYY4xxy6sBQkR6iMgWEdkmIo+4KQ8TkRki8oeIbBCRYa71tUVkoYhscq2/35v1NMYYk53XAoSI+ANvAz2BJsBAEWmSZbN/AhtVtSXQGXhFRIKAFOAhVW0MXAr8082+xhhjvMibLYhLgG2qukNVk4DPgGuzbKNAeRERoBxwFEhR1X2qugpAVU8Am4BaXqyrMcaYLLwZIGoBGYcFx5L9S/4toDGwF1gH3K+qaRk3EJFIoBXgdr5NERkuIitEZMUhd+msjTHGFIg3A4S4WZf1mdqrgTVATSAaeEtEKqQfQKQc8CUwSlWPuzuJqk5Q1Taq2qZq1aqeqLfPvPbaa5w6dcrX1TDGGMC7ASIWqJ1hOQKnpZDRMOArV9bZbUAM0AhARAJxgsNUVf3Ki/UsMixAGGOKEm8GiOVAfRGJct14HgB8l2Wbv4CuACJSHWgI7HDdk3gf2KSqr3qxjl538uRJrrnmGlq2bEmzZs34/PPPmT9/Pq1ataJ58+bcfvvtJCYm8sYbb7B3716uvPJKrrzySgDuuece2rRpQ9OmTXnyySd9fCXGmNLGa6k2VDVFRO4FfgD8gUmqukFE7naVvws8DUwWkXU4XVJjVPWwiHQChgDrRGSN65CPquqs866Yp6eGzJKZNas5c+ZQs2ZNvv/+ewDi4+Np1qwZ8+fPp0GDBtx6662MGzeOUaNG8eqrr7Jw4ULCw8MBZya6ypUrk5qaSteuXVm7di0tWrTI9yUbY0xBeHUchKrOUtUGqnqRqj7rWveuKzigqntVtbuqNlfVZqr6sWv9z6oqqtpCVaNdr/MPDj7QvHlz5s2bx5gxY1iyZAk7d+4kKiqKBq65mm+77bYcs7ZOmzaN1q1b06pVKzZs2MDGjRsLs+rGmFKu9CXry+0v/pCQ3MvDw8/ZYsiqQYMGrFy5klmzZjF27Fi6d++ep/1iYmJ4+eWXWb58OZUqVWLo0KHpmV+NMaYwWKoNL9u7dy8hISEMHjyY0aNHs3TpUnbu3Mm2bdsAmDJlCldccQXgTDt64sQJAI4fP05oaChhYWEcOHCA2bNn++wajDGlU+lrQRSydevW8fDDD+Pn50dgYCDjxo0jPj6em266iZSUFNq2bZs+9/Tw4cPp2bMnNWrUYOHChbRq1YqmTZtSt25dOnbs6OMrMcaUNpbu2/iM/W6M8T1L922MMSbfLEAYY4xxq0Tdg9hyZAudJ3fOtO6/0f9FVUnTNLYd3ZZtnyohVQgPCSc5NZkdx3ZkK68aWpXKZSuTlJJETFxMtvLq5apTMbgiZ5LPsCt+V7byGuVrUKFMBU4ln2J3/O5s5bUq1KJcUDkSkhLYc3xPtvLaYbUJCQzheOJx9p3Yl638wrALCQ4MJu5MHAcSDmQrj6oYRVBAEEdPH+XQyey5qupWqkugfyCHTx3myKkj2crrVa6Hv58/B08e5NjpY9nKG4Y3BGB/wn7iz8RnKhMRGlRxHufde2IvJxJPpJepKgdPHqQxThfT2Hlj+TX210z7R1SI4OMbPgZg1JxRrNm/JlN5gyoNmNBnAgDDZwznzyN/ZiqPviCa13q8BsDgrwYTezw2U3n7iPY83+15AG6cdmO26+8a1ZV/XfEvAHpO7cnp5NOZyns36M3oDqMBsn3uAG5uejMj2o7gVPIpek3NPr5maPRQhkYP5fCpw/Sb1i9b+T1t7qF/s/7sjt/NkK+HZCt/qP1D9GnYhy2Ht3DXzLuylT9++eN0q9uNNfvXMGrOqGzlz3V9jg61O7B091Ienf9otvLXerxG9AXRzNsxj2cWP5OtfHzv8TQMb8iMLTN45ddXspVPuX4KtcNq8/n6zxm3Yly28uk3Tyc8JJzJayYzec3kbOWzBs0iJDCEd5a/w7QN07KVLxq6CICXl77MzD9nZiorG1iW2YOcBzue/ulp5sfMz1ReJaQKX978JWCfvdyU+BbEKT3FkSNHKEn3Woo7VSXxRCIHEw/6uirGmFyU+JvUycnJxMbG2hiCIiY4OJiIiAgCAwN9XRVjSrXcblKXqC4mdwIDA4mKivJ1NYwxptgp8V1MxhhjCsYChDHGGLcsQBhjjHHLAoQxxhi3Sn2AUFVW7DzKjkMJvq6KMcYUKaU+QCQkpnDrpN95a0H2QXTGGFOalfoAUT44kP5ta/PdH3vZF3/63DsYY0wpUeoDBMDtHaNIU2Xy0p2+rooxxhQZXg0QItJDRLaIyDYRecRNeZiIzBCRP0Rkg4gMy+u+nlS7cgg9m9fgk9/+4sSZZG+eyhhjig2vBQgR8QfeBnoCTYCBItIky2b/BDaqakugM/CKiATlcV+PGn5ZXU4kpvD58uwJ9YwxpjTyZgviEmCbqu5Q1STgM+DaLNsoUF5EBCgHHAVS8rivR7WsXZFLoirzwS87SUlN8+apjDGmWPBmgKgFZPxzPNa1LqO3gMbAXmAdcL+qpuVxXwBEZLiIrBCRFYcOZU9nnR/DL6vLnrjTfL8ue1ptY4wpbbwZIMTNuqypY68G1gA1gWjgLRGpkMd9nZWqE1S1jaq2qVq1asFrC3RpVI161crx+vytJFsrwhhTynkzQMQCtTMsR+C0FDIaBnyljm1ADNAoj/t6nJ+fMLZnI3YcOsnHv2Wf/McYY0oTbwaI5UB9EYkSkSBgAPBdlm3+AroCiEh1oCGwI4/7ekWXRtXoVC+c1+ZtJe5UUmGc0hhjiiSvBQhVTQHuBX4ANgHTVHWDiNwtIne7Nnsa6CAi64D5wBhVPZzTvt6qa0YiwuO9G3PiTDKvz99aGKc0xpgiqcTPKFdQY79axxcrdvPdvZ2oXbksACFBAfj7ubs9YowxxVOpnlGuoB68qgEz/thLrzeWpK+rXqEMt7aPZFC7OlQMCfJh7Ywxxvvy1IIQkS+BScBs12OoRZInWxAA6/fE89uOIwCkqbJk62GWbD1McKAfN7aO4PZOUVxUtZzHzmeMMYUttxZEXgNEN5wnji4FvgAmq+pmj9bSAzwdINzZvP84k36O4Zs1e0lKSaNLo2r0aVmDQH/ndk7l0CAujaqCn3VFGWOKgfMOEBkOFAYMBB7DGcg2EfhYVYtEAqMCB4ikU86/QSF53uVwQiIf/7aLj3/bxeGEzE871Q0PZVinKG5sXYuQIOvFM8YUXR4JECJSBRgMDMEZkzAV6AQ0V9XOnqnq+SlQgDgdB+M6QKshcOXYfJ8zMSWVv46cSl/euO847/8cw9rYeMLLBTF+SBsuvrBSvo9rjDGFIbcAkafHXEXkK2AJEAL0UdW+qvq5qo7EyaFUfJWtCLUvgV9eh/g9+d69TIA/9auXT39dG12Lb//ZkWl3tSe0TAC3TPyNuRv2e77exhjjZXm9B9FFVRcUQn3OS4G7mI7thLfaQtMb4IbxHqvP4YRE7vhwBeti43j46ka0iAgDIKxsIM1qhXnsPMYYU1CeeMy1sYisUtU41wErAQNV9R0P1dG3KkXCpSPgl9eg3V1Qq7VHDhtergyf/qMd9326mv/OyXxP/+nrmjHk0gs9ch5jjPGGvLYg1qhqdJZ1q1W1lbcqVhDn9RTTmePwZmuoUg+GzQbx3FNIqWnKuj3xJKU4Twi/vXAbv24/wlcjOlhLwhjjU55oQfiJiKgrmrgm9ClZI8WCK8CVj8HMUbD+S2jeL2/7xa6Ejd+Qnmy24oXQ5nbw80/fxN9PiK5dMX25XrVornljCSOmrmLmfZ2oEBzIriMnmbN+P22jKtO6jt3UNsb4Xl4DxA/ANBF5F+eb8G5gjtdq5Sutb4VVH8HXd4OmQYubc99+w9fw1XBQBf9A59+U0xCzGG6YAIFl3e5WOTSINwe2ov+E3xj5yWrKBPjx46YDnG3MtapTkTs6RdGzWQ1L7WGM8Zm8djH5AXfhZF4VYC7wnqqmerd6+eORgXKn4+DzwbBzCXR9Ejo94L676de34YfHoHY7GPgphFTOfb0b43/azvOzN1MxJJBB7erQ7+LaLNl6iEk/x7DzyCm6NKrGW7e0srEUxhiv8dhAuaLOYyOpUxLhm3ucrqYq9cA/S29aajIc2QqN+8INEyEwOHP5hq/hq7ugYh0Y/CVUcn8zWlVZuesYTWuGUTbo7y6p1DTl49928e8ZG2hWK4xJQ9sSXq7M+V+XMcZk4YlUG/WB54EmQPq3oarW9VQlPcGjqTbS0mDpG7Anh+PViHZaFxnuNWSyayl8OgACguGWaVAzOt9V+HHjAUZ+uopq5YN5fUA0rezehDHGwzwRIH4GngT+B/TBycskqvqkJyt6vgojF1O+HNwMU/vBqaNw80dQv1u+D7H6r2Pc+eEKjpxM4uILK3Fnpyi6N73A7k0YYzzCEwFipapeLCLrVLW5a90SVb3Mw3U9L0UuQAAc3wdTb4KDG6HvG9BqcL4PceJMMl+siOWDpTHsPnqaiEplGdohkv5ta1M+ONALlTbGlBbnnWoDOOO6Ub1VRO4VkeuBah6rYUlWoQYMmwVRl8O3/4RF/4V83vcpHxzI7Z2iWDT6St4d3JoaYcE88/0m2j+/gAmLt1OS7iMZY4qOvLYg2uJM/VkRZ5rQCsBLqvqbV2uXT0WyBXFWShLMuA/++NR5nPaa/4F/wZ9OWhsbxxvztzJv00EGtavDv/s2JcCVcvyP3XH4idA8wgbhGWNyd14D5VyD4m5W1YeBBJz7D3k9cQ/gdcAf57HYF7KUPwwMylCXxkBVVT0qIg8Ad+KMu1gHDFPVM3k9d5ETEATXjYMKtWDJy3BiP/T7AMoULNdhi4iKTLy1DS/+sIVxi7azP/4M17WqxQe/xLDqrzgC/IT/3tiCGy+OyLRfYsrfTyYH+Pl55F5GapqSkuZ+Hqkgfz/Eg6PSjTGFJ68tiAVAV81HX4YrsPwJXAXEAstx8jdtzGH7PsADqtpFRGoBPwNNVPW0iEwDZqnq5NzOWaRbEBmtmATfPwQXtIBBX0C58+utm/LrTp78bgNpCnUqhzC0QyTzNx/gl21HGN29AXddcRGz1u1j0s8x/BEbn75fuTIB3NQmgmEdoqhTJe9zYWS0fOdR7vl4ZbY5Mc5qWL08t3eK5NroWgQH5vDElzHGZzxxk/oVoD7ObHInz65X1a9y2ac98JSqXu1aHuva5/kctv8EWKiqE10B4jegJXAc+AZ4Q1Xn5lbPYhMgALbMgenDoGxl98kBA8rA5f8HVRvk6XC/7ThCwpkUrmxUDX8/ISkljTFfruXr1XuoEBzA8TMp1A0PpXfLmpQJcLqi/jxwgu/X7iNNlQ4XhVM+OPcGZYC/H1c3rU6PphcQ4O/H7HX7uP/zNdSqWJZ+WVoqACmpyuz1+9i8/wRVQoNoG1k5fcxht8bVs7VujDGFzxMB4gM3q1VVb89ln35AD1W907U8BGinqve62TYEp5VRT1WPutbdDzwLnAbmquqgrPu5thsODAeoU6fOxbt27Trn9RQZsSthzhhITMheFr8bqjaCO34Ev7w+S5CZqvL6/K38sTuOIe0vpHODatmmQt0ff4aPft3Jgs0HSTvHZyH+dDIHjidSq2JZOtULZ9rK3bSqXZH3bmtL5VD3qblUlV+3H+GDpTvZdeRk+jnDy5dhwUOdC3RdxhjP8clIahG5Cbg6S4C4xDXJUNZt+wODVbWPa7kS8CXQH4jDablMV9WPcztnsWpBnMvqqfDtCLjhPWhxk69rAzj3GhZsPsh7S3awLOYoVzetzusDWuW76+jFOZuZsHgHm57ukT6XtzHGN847m6urBZEtkuTWgsBpEdTOsByBM1WpOwOATzMsdwNiVPWQ6/xfAR2AXANEidJyIPw+HuY9BY1755j4rzD5+wlXNanOVU2qszfuNBdUCM7WIsmLulXLkZKmxB47TVR4qBdqaozxhLz++TYT+N71mo/zmKubfpFMlgP1RSRKRIJwgsB3WTcSkTDgCuDbDKv/Ai4VkRBxHoHpivOYbenh5wdXPwfHY+HXt3xdm2xqVixboOAApAeFHYfO9REyxvhSngKEqn6Z4TUVuBlodo59UoB7cVKFbwKmqeoGEblbRO7OsOn1OPcYMt78XgZMB1bhPOLqB0zIx3WVDJGdoFFvWPI/57HYrE4egaST2dcXcRdVPRsgil/djSlNCtoBXB+oc66NVHWWqjZQ1YtU9VnXundV9d0M20xW1QFu9n1SVRupajNVHaKqiQWsa/F21X8gNclJ/Jdw6O/12xfC6y1h6s35HpntaxVDgqgUEsiOwxYgjCnK8hQgROSEiBw/+wJmAGO8WzUDQJWLnER/BzfD+93gyHb44zMnCaB/IOz6GTZ+e+7jFDF1q5azLiZjiri8djGVV9UKGV4NVPVLb1fOuDTqBbfNgMQTMP4K+PouuLADjFwJ1ZrAj084c1gUI3XDQ4mxFoQxRVpeWxDXu24mn12uKCLXea1WJrvabZ0xERXrQPQgGPSlM1vd1c9C3C5Y9u65j1GERFUN5eCJRE6cSfZ1VYwxOcjrPYgnVTU9R4OqxuHMD2EKU5WLYMRSuO4dJ7cTwEVdoP7VsPjlzPcoiri64U4OKmtFGFN05TWdqLtAYhMlFxXdn4Fx7eG9Lk7qjqwiOznbFKGkeXVdTzLFHD5Ji4iKvq2MMcatvLYgVojIqyJykYjUFZH/ASu9WTGTD1UbQJ83oGpjKFc98yugjDOOYstsX9cykwurhOAnsN0edTWmyMprK2Ak8C/gc9fyXOBxr9TIFEyrQc4rq9RkGNcB5j4O9br93TXlY2UC/ImoFGJdTMYUYXl9iumkqj6iqm1cr0czDmwzRZh/oNO9dHQ7rHjf17XJJCo81B51NaYIy+tTTD+KSMUMy5VE5Aev1cp4Vv3uUPdKWPQCnDrq69qkq1vVedTVpkw1pmjKaxdTuOvJJQBU9ZiI2JzUxYWIk9fp3Y7w/YPQoEfBjhNUDhr2BD/PTPxTNzyUU0mpHDieyAVhwR45pjHGc/IaINJEpI6q/gUgIpG4ye5qirDqTaDd3fDbO7Dh64If54oxcOWjHqlS3arOo647DiVYgDCmCMprgHgM+FlEfnItX45rkh5TjFz9nBMkNPXc27oz7yn45Q1ofRuE1Trv6qRndT18kg71ws/7eMYYz8pTgFDVOSLSBicorMFJzX3ai/Uy3iAClS4s+P5XPe1MlTr/P3DD+POuzgUVgikb6G9ZXY0povJ6k/pOnHkgHnK9pgBPea9apkiqdCG0HwFrP4M95z8Mxs9PiAoPZbs9yWRMkZTXgXL3A22BXap6JdAKKD55HYzndHoQQqvCnEc9kma8RUQYP/15iFsm/sb8TQdIS7NbW8YUFXm9B3FGVc+ICCJSRlU3i0hDr9bMFE3BFaDL4zDjflj6JnS87++yYzth+u1wdIf7fetdBX3fyDR96uO9m3BhlVA+XLqTOz5cQd3wUIZ1jOTGiyMICbJsLsb4kuTlGXQR+RoYBowCugDHgEBV7eXV2uVTmzZtdMWKFb6uRsmXlgrTboXNM6H9vc69if1/OJMXpSZC85uz531KTIA/PoWItjDwMwitkqk4OTWNWev2MennGP6IjSesbCBDO0Qysks9AvwLOq+VMeZcRGSlqrZxW5bfQUoicgUQBsxR1SQP1M9jLEAUorRUmD0Glk90Msr+tcxJPz74S6iaQ+Ny47fw5T+gYm0YNB0qR2XbRFVZuesY7y2JYc6G/XRtVI03b2llrQljvCS3AJHvP81U9SdV/S4vwUFEeojIFhHZJiKPuCl/WETWuF7rRSRVRCq7yiqKyHQR2Swim0SkfX7rarzIzx96vQTd/g3bF0CVus58FTkFB4Am18Jt38HJw/CV+6ekRYQ2kZV5d8jFPH1dMxZuOcjAics4nFC8JkQypiTIdwsizwcW8Qf+BK4CYoHlwEBV3ZjD9n2AB1S1i2v5Q2CJqr4nIkFASMbR3O5YC8JHDmyESpEQFJK37X96CRY+Cw9vg9Dcxz/M3bCf+z5bTZXQMoy48iJuaBVB2SDPjOQ2xni4iykfJ20PPKWqV7uWxwKo6vM5bP8JsFBVJ4pIBeAPoK7mo4IWIIqJPatg4pVww0RocfM5N1/91zH+9e161u85TqWQQK5vFUHFkMBs2wX6+3F10+rpI7SNMeeWW4DwZsduLWB3huVYoJ27DUUkBOgB3OtaVRfnMdoPRKQlztwT97vLICsiw3GN6q5Tp47HKm+8qEY0hITD1h/zFCBa1anEjHs78XvMUd7/OYbJS2PI6WnYF3/YTJeG1bijUxTtL6qCFKFJkowpbrwZINz9z8ypNdAH+EVVz6YaDQBaAyNVdZmIvA48gjMnReYDqk4AJoDTgjjvWhvv8/ODel1h2zxIS3OWz0FEaFe3Cu3qViEtTd1+kI4kJPLxsr+Y+tsubnlvGY1rVOCOTlH0aVmDMgHWLWVMfnnz+cFYoHaG5Qhgbw7bDgA+zbJvrKoucy1PxwkYpqSo1w1OHYF9q/O9q5+f4O/mVa1CMA9e1YBfHunCf29sTmpaGqO/+INO/13I0m2HvXARxpRs3gwQy4H6IhLlusk8APgu60YiEgZcgZPfCQBV3Q/szjAYryvg9ua2KaYu6gIIbJvv8UMHB/rTv20dfhh1OVPuuIQKwQH885NV7Iu39GHG5IfXAoSqpuDcU/gB2ARMU9UNInK3iNydYdPrgblu7i+MBKaKyFogGnjOW3U1PhAaDjVbOd1MXiIiXFa/KuOHtCExJY2Rn6wmOTXNa+czpqTx6hBVVZ2lqg1U9SJVfda17l1VfTfDNpNVdYCbfde4pjdtoarXqeoxb9bV+ED9qyB2uddnuatXrRzP39CcFbuO8fLcLV49lzElieUwML5TrxtoGuxY5PVTXRtdi4GX1GH8TzuYv+mA189nTElgAcL4Tq2LIbiiV7uZMnqyTxOa1KjAQ1/8wZ44ux9hzLlYgDC+4+fvzI+9dprz8rLgQH/eGdSalFTl3k9WkZRi9yOMyY0FCONbPf8LdS6Fr/4BS171yBwTuYkMD+W/N7Zg9V9xvDhnMycTU5j8SwxdX1nEmOlrycvA/ZTUNP71zXo6vrCAN+dv5ejJIpWz0hiP8VqqDV+wVBvFVEoifHMPrP/SmTOiXHVnfbVGTjpxL4yGfuLb9Xz06y7KlwngRGIKdSqH8NfRUzxzXTMGX5rztKynklK495PVLNh8kGa1KrB+z3HKBPjRv21tHu3VmOBAG5BnihdfpdowJm8CysAN70GlKFj7ORzcBGnJsOZjqHghNOnr8VM+dk1j9sadITjQj9s7RREdUZFhk5fzn5kbia5dkWa1wgA4ePwM2w46U6KmqvLyD1tYtyc+PZBsPXCC93+OYcpvu9i49zgTb21DpdAgAJJS0lizO44U16O1FcoGph/XmOLAWhCmaEpNgXc7Oq2Lfy5zgoiXHT2ZRK/Xl1Am0I//3tiCT3//i+/X7iMlQ+Kn4EA/3hzYmquaVM+07/dr9/HAtDVEVCrL6/1bsXjrIT5cupODJzKnKX/5ppb0uzjC69diTF75JJurL1iAKGG2zoOpN0L3Z6DDyEI55YqdR+k/4TdS05TQIH9ublubq5pUx9/VzVWnSgg1wsq63ff3mKP846MVxJ9OBuCy+uHcckkdKrtaFM/N3sy+uNMsHN2Z0DLWeDdFgwUIU3x9fCPsXg73rTrn3BGeMmvdPg4cP8ONF0dQITh7WvHcbDuYwFerYrk2uhYNLyifqWzlrmPcOG4p93Wpx4PdbUp3UzR4dEY5YwpV92chKQEWuZ1GxCt6Na/BsI5R+Q4O4Iza/r8ejbIFB4CLL6xEn5Y1mbBkB3ttHIYpBixAmKKtWiNoMwxWfADxe3xdm/M2pkdDVOGlHyzlhyn6rCPUFH3t/wnL34O1n8FlD/m6NuclolIId14WxdsLt9O7RQ26Nq5+7p3yadvBBD74JYYVO8+dviykjD83tI7gxta1CAmyrwOTmd2DMMXDB73gxH4YudIr4yIKU0JiCv3H/8rm/Sd47vpm9G97/jMhqio/bzvM+z/HsGjLIYIC/OhUL5wg/9w7CXYfO8WGvccJKxvILe3qcFv7SC4ICz7n+U4lpfDjxgO0i6qSp+1N0WXjIEzxF30LfPtP2P071HE7c22xUa5MAJ/f1Z4RU1cx5st17Ik7wy2XFCxIKMriPw8x6eedbDlwgvByZXjwqgYMaleHKuXO/WiwqrJy1zHe/zmG8T9tZ+LiHVzToga3dYikppuntU4mpfDFilg+/f0v4k8nc32rWvyvf3SB6m6KPmtBmOIhMQFebgDNb4S+b/q6Nh6RnJrGo1+t44uVsed9rEYXlOeOTlH0ja5Z4OlVdx89xQe/7GTait0kJKbkuJ2fwNVNLyAhMYU1u+NY+fhVBAXY7cziyh5zNSXDNyNg43cw+k8ICvF1bTxCVflx4wGOnEc+p6jwUNpFVUY81PV2/EwyCzYd5HRyarYyP4EOF4VTu3II8zcd4I4PVzB5WFs6N6zmkXObwmddTKZkiL4F1kyFTTOgZX9f18YjRITuTS/wdTUyqRAcyHWtap1zu471wgkN8mfO+v0WIEooaxea4qNOB6gU6eRoSkl0Xqk5d4W45csWcwlqrYOTPr1L4+rM3XiA1LSSdW3G4dUAISI9RGSLiGwTkUfclD8sImtcr/UikioilTOU+4vIahGZ6c16mmLCzw9a3gIxi+GZas7r+QhYPTVv+5+Jh3cuhaVvebee7uxeDi/Vg+XvF/65vahnsws4ejKJ32O8O22s8Q2vdTGJiD/wNnAVEAssF5HvVHXj2W1U9SXgJdf2fYAHVDXjJ+1+YBNQwVv1NMXMpXc79x9SXX322xfCtyPg+F64fHTuj8AueQUObYYFz0DT6yHs3N0oHpGWBrP/D04dge8fhPhY6PpEsX9cF+CKBlUpE+DHnPX7aH9RlVy3nbl2Lxv2HueWS+pQu3LJuIdU0nnzHsQlwDZV3QEgIp8B1wIbc9h+IPDp2QURiQCuAZ4FHvRiPU1xEhyWOXFf+5Hw3UhY+AzE7YSGvZz1/kEQdfnfWWCPxsBv45x5sGOWwPx/ww0TCqfO676Avaug71uwZwX8/KoT0K59C/zzn86jKAktE8AVDaoyZ8N+nuzTFD8/90Fvze44Hvh8DcmpyvifttOj2QVc07wmgf7Ztw8rG0jbyMo5Hqsgth08QfUKwZQvQPqU0sybAaIWsDvDcizg9gF2EQkBegD3Zlj9GvB/QPakNpn3HQ4MB6hT5/wHHJliJiAIrn8XwiJgycuw+uO/yy7sCAOmQtlKMO9J8AtwHpH9faLzJX3JXRBxsXfrl3TKCUY1oiF6ELQa7NR1wTMQXg8uf9i75y8EPZtfwNyNB1gTG0frOpWylcefSuafU1dRrXww793Whm/X7OWTZbuYtW5/jsesWzWU2ztGcWPrCMoGnd8kTFOX7eJf36yneURFvrirvT2Smw9ee8xVRG4CrlbVO13LQ4BLVDVb3mYR6Q8MVtU+ruXeQC9VHSEinYHRqtr7XOe0x1xLuaM7IPGE837fH/D9Q84kRJc/DF/dCZ3HQudH4MxxeLM1VL4Ibp/j3a6eRf+FRc/BsNlwYYe/1382yOkeu28VlC9aTzHlV/zpZNo88yOCpLcIGteowO2doriqSXXu+XgVP/15kGl3taeVK4CcSkphx6GTbo+37WACk36JYW1sPIH+4nY0eGCAH72a1+D2jlHUq1bO7XFUlVfm/slbC7fRtGYFNuw9zu0do3iiTxMPXXnJ4JNxECLSHnhKVa92LY8FUNVsaTlF5GvgC1X9xLX8PDAESAGCce5BfKWqg3M7pwUIk0nMEueLODEeyteEkSsgKNQpWzkZZtwPTa5zWhhZRV0OzW7I23n2rYVVH0Gamyeq1n7udGv1n5J5/ZHt8HY753Hda9/Oz1XlbOs82OyF5zn8g+CS4U6LJwffrN7D+j3xAKSkKfM3H2D30dNUCgnk2KlknujdhNs7ReX5lKrKil3HmLfpAKmp2b+jDickMmv9fpJS0risfrjbexq7j55iydbDDGhbm2eua8bTMzfy4a+7eHfwxfRoVryDsif5KkAEAH8CXYE9wHLgFlXdkGW7MCAGqK2q2f6ksBaEOS8HNjr3KC57CBr1+nt9WipMu9VJ3ZFVahKciYPL/w+ufDT3FsbWH2HabYBCkJu/ZMtVc7q5KkVmL/vhMfj1bbjrJ6jRMp8XlsWy8TB7DJQpDwEezo2UeBwCQ2DgZ3lOc5Ka5gwA/HDpTupUDuGFG5t7bCDfWYcTEpn62198tTqWk4nZB/X5+8Gt7SMZ0fkiRITElFRuevdXYg6fZObITlxYJTTHY8edSmKra6rZrCqFBOXYaimOfDaSWkR64dxL8AcmqeqzInI3gKq+69pmKNBDVQfkcIzOWIAwhSk1BWaOgtVTnMdq+77h/mbyqo9gxiio3hQGfZH/rqLTcfBGK2f/22YUrKsrLQ3mPQFL34RGveHG9yDQ/Yx3BXZ0B3zcD47vcY7fuI9nj1+Idh89xTVvLCExJY0bWkdwR6dI6lX7+zbn2e6tr1bFciY5LcfjXBJZOb0Lzd+DN9N9wVJtGJNfqvDTi879g9CqEJD1S1chfjdc1BVu/tD5y70gfp8Is0ZDhQiQAtw8TU2ChP3Q9h/Q87/gd343dHN08jB8OgBiV0DPF6HdcO+cpxDsOJTAhMU7+Gr1HpJS0qhV8e/f7Z640wQF+HFDq1pc3ewCAv2y/0427z/O5KU7iT12mjqVQxjaIZKb29amXDGdRtYChDEFteFr+HOu+7LKUdDpgfN7VDU1BRa/BHF/FfwYddpB69u8P64i6RR8eSds+R463Afd/u0MXiymjiQk8tny3ZlulkeFhzDgkjqEnyMTbkpqGj9uPMB7P8ewctcxypcJoG90TSqFOPOPlwnw45oWNahbteh3RVmAMMZ4RloqzHoYVrwPzfrBde/8PdYkL/se2e6+LDQcQiq7Lyvi1uyO4/2fY/hhw/70lCOpaYoIdG1UjVvbR1LT1UopE+BX5AYJWrI+Y4xn+PnDNa9Axdow7ynnCbBrXj73fqpOF9XWHFpjgSHQ7wNo2MOj1S0M0bUr8ubAVpnWHTqRyJTfdjH1t13M25T5QYgHujXg/m71C7OKBWYtCGNMwcx62Mktdc9SZ+7w3GyZ7QSIS0dALTeDE5e+CfvXwjWvOnOQlxBnklNZsvVweur0Oev3MXv9fj66/RIuq1/Vx7VzWBeTMcbzTh2FN6Ihoi0M/vLv9buWOilRqjd1llOSYFx75yb8PUvd37NJTIAvhsK2H6HN7VDF9Rd2SBVo3s97N98L2amkFK57+xeOJCQx6/7LqF4h8yPJya57G/viz7jd/7L64TSoXsAHInJgXUzGGM8LqeyMFZn7mDNIr343J9/VnLHOfYl+k6DRNc79iiPb4JZpOd/QL1MOBn7qjH5fMSlz2abvvPP4rg+EBAXwzqDW9H3rF0Z+spp3BrfGT4Qzyal8s2YPHy3dxf7j7oMDQOXQIBaO7kxY2cLJKWUtCGNMwaUkwTvtnNHW9brBr29Bw2ucR2/3roYu/4JfXoearWDI13l70irxhHNDG+CPT52AE9HWGagXmnvG2OLi69WxPPD5H9nWd6xXhTs6RXFxncqQ5Ue17eAJ+r37K8Mvq8vYXo09VhfrYjLGeM+mmfD5IOf9JcOhxwuQcgam3wF/zna6lu7+BaoXMAfSxm/hy38441GqNsxeHlAGLhvt/cSLHrbAlY4EnLjZNrIyjWvkPrPB6C/+4Ls1e5n34BXUqeKZp6EsQBhjvEfVSRtSKRIu+cffrYTUFFj0PJStmDlFe0H89ZuTATf5dPayuL+cVke/SZnTqZRAB46f4cqXF3FFg6qMG+yZgGgBwhhTciUchE9udjL49nrZucntKUVwUqc35m/l1R//5PPhl9Ku7vl3uVmAMMaUbEkn4YthsPUHzx2zerOcEy360OmkVLq8sojUNOUfl9Wl/yW1qXAeEyFZgDDGlHypKbDqQzh56PyPlZbi5MnyD4JB05yb7EXImt1xPDdrE7/HHCU0yJ+b2tTmkZ6NCA7M/+PAFiCMMSa/Dm1xstieOgI3f+Q8xlvErIuNZ9IvMcQcPsnXIzoUKKW6BQhjjCmIE/thaj9nXpE+r0PrIb6ukVspqWkEuJl5Ly9yCxDFNxWjMcZ4W/kLYOgsZ4bB7+6FRS84T20VMQUNDudiAcIYY3ITXMGZEKrlLc5ju9+NhNRkX9eqUFiqDWOMORf/QCe1eVgELH7R6Xq6abKTIqQEsxaEMcbkhQh0eQx6vwbb58Pka5wxGCWYV1sQItIDeB1nTur3VPWFLOUPA4My1KUxUBUIBT4CLgDSgAmq+ro362qMMXnSZhiUrwHTh8FbbZ3JjgCCK0LvV6FGS59Wz5O89hSTiPgDfwJXAbHAcmCgqm7MYfs+wAOq2kVEagA1VHWViJQHVgLX5bTvWfYUkzGm0OxZBcvGQ5rrfsSuXyHxuPNIbL2uvq1bPvgq3fclwDZV3eGqxGfAtUBOX/IDgU8BVHUfsM/1/oSIbAJq5bKvMcYUrlqt4Ybxfy8f3wdTb3LSflzzCtTtXHh1EX9nlj8P82aAqAXszrAcC7Rzt6GIhAA9gHvdlEUCrYBlnq+iMcZ4SIUaMGwWTBsCM+4v3HOHVoOHt3r8sN4MEO6G9OXUn9UH+EVVj2Y6gEg54EtglKoed3sSkeHAcIA6deoUvLbGGHO+givALV/AllmQfKrwzhtQxjuH9cpRHbFAxjZPBLA3h20H4OpeOktEAnGCw1RV/Sqnk6jqBGACOPcgzqfCxhhz3gKCoOl1vq6FR3jzMdflQH0RiRKRIJwg8F3WjUQkDLgC+DbDOgHeBzap6qterKMxxpgceC1AqGoKzj2FH4BNwDRV3SAid4vI3Rk2vR6Yq6onM6zrCAwBuojIGterZM8EYowxRYwl6zPGmFLMkvUZY4zJNwsQxhhj3LIAYYwxxi0LEMYYY9yyAGGMMcYtCxDGGGPcsgBhjDHGLQsQxhhj3LIAYYwxxi0LEMYYY9yyAGGMMcYtCxDGGGPcsgBhjDHGLQsQxhhj3LIAYYwxxi0LEMYYY9yyAGGMMcYtCxDGGGPcsgBhjDHGLa8GCBHpISJbRGSbiDzipvxhEVnjeq0XkVQRqZyXfY0xxniX1wKEiPgDbwM9gSbAQBFpknEbVX1JVaNVNRoYC/ykqkfzsq8xxhjv8mYL4hJgm6ruUNUk4DPg2ly2Hwh8WsB9jTHGeFiAF49dC9idYTkWaOduQxEJAXoA9xZg3+HAcNdigohsKWB9w4HDBdy3uCqN1wyl87pL4zVD6bzu/F7zhTkVeDNAiJt1msO2fYBfVPVofvdV1QnAhPxXLzMRWaGqbc73OMVJabxmKJ3XXRqvGUrndXvymr3ZxRQL1M6wHAHszWHbAfzdvZTffY0xxniBNwPEcqC+iESJSBBOEPgu60YiEgZcAXyb332NMcZ4j9e6mFQ1RUTuBX4A/IFJqrpBRO52lb/r2vR6YK6qnjzXvt6qq8t5d1MVQ6XxmqF0XndpvGYondftsWsW1ZxuCxhjjCnNbCS1McYYtyxAGGOMcavUB4jSktJDRGqLyEIR2SQiG0Tkftf6yiLyo4hsdf1bydd19TQR8ReR1SIy07VcGq65oohMF5HNrt95+5J+3SLygOuzvV5EPhWR4JJ4zSIySUQOisj6DOtyvE4RGev6ftsiIlfn51ylOkCUspQeKcBDqtoYuBT4p+taHwHmq2p9YL5ruaS5H9iUYbk0XPPrwBxVbQS0xLn+EnvdIlILuA9oo6rNcB5uGUDJvObJOAOLM3J7na7/4wOApq593nF97+VJqQ4QlKKUHqq6T1VXud6fwPnCqIVzvR+6NvsQuM4nFfQSEYkArgHey7C6pF9zBeBy4H0AVU1S1ThK+HXjPJVZVkQCgBCcsVMl7ppVdTFwNMvqnK7zWuAzVU1U1RhgG873Xp6U9gDhLqVHLR/VpdCISCTQClgGVFfVfeAEEaCaD6vmDa8B/wekZVhX0q+5LnAI+MDVtfaeiIRSgq9bVfcALwN/AfuAeFWdSwm+5ixyus7z+o4r7QEiP+lASgQRKQd8CYxS1eO+ro83iUhv4KCqrvR1XQpZANAaGKeqrYCTlIyulRy5+tyvBaKAmkCoiAz2ba2KhPP6jivtAaJUpfQQkUCc4DBVVb9yrT4gIjVc5TWAg76qnxd0BPqKyE6c7sMuIvIxJfuawflcx6rqMtfydJyAUZKvuxsQo6qHVDUZ+AroQMm+5oxyus7z+o4r7QGi1KT0EBHB6ZPepKqvZij6DrjN9f42Mqc8KdZUdayqRqhqJM7vdoGqDqYEXzOAqu4HdotIQ9eqrsBGSvZ1/wVcKiIhrs96V5z7bCX5mjPK6Tq/AwaISBkRiQLqA7/n+aiqWqpfQC/gT2A78Jiv6+PF6+yE07RcC6xxvXoBVXCeetjq+reyr+vqpevvDMx0vS/x1wxEAytcv+9vgEol/bqBfwObgfXAFKBMSbxmnMSm+4BknBbCHbldJ/CY6/ttC9AzP+eyVBvGGGPcKu1dTMYYY3JgAcIYY4xbFiCMMca4ZQHCGGOMWxYgjDHGuGUBwpQIIrJIRLw+Ob2I3OfKjjq1gPtPFpF+nq6Xp4hIZxHpUID9IjNmFzUlg9emHDWmuBCRAFVNyePmI3CeJY/xZp18wZXkrjOQACzNx355zg5qihdrQZhC4/orc5OITHTl7Z8rImVdZektABEJd6XHQESGisg3IjJDRGJE5F4RedCVhO43Eamc4RSDRWSpaz6AS1z7h7ry5y937XNthuN+ISIzgLlu6vqg6zjrRWSUa927OInwvhORB7Js7y8iL7nOs1ZE7nKtFxF5S0Q2isj3ZEgWJyK9xJmv4WcReUP+nq8ipzo3FZHfRWSN6xz13dQ7QUReEZFVIjJfRKq61l8kInNEZKWILBGRRq71k0XkVRFZCHwO3A084DrHZVlbPCKS4Pq3szjzi3wCrHMVB4jIh666TReRkHN9JkwR5+tRgfYqPS8gEmdeimjX8jRgsOv9Ipxc/gDhwE7X+6E4KYrLA1WBeOBuV9n/cJIOnt1/ouv95cB61/vnMpyjIs6o+VDXcWNxM7IWuBjnSy8UKAdsAFq5ynYC4W72GQ487npfBmcUcxRwA/AjzvwENYE4oB8QjJNlM8q1z6f8PdI7pzq/CQxyrQ8Cyrqph2bY5gngLdf7+UB91/t2OGlHwJlbYCbg71p+Chid4XiTgX4ZlhNc/3bGSQJ4tv6RrnN3dC1PyngcexXPl7UgTGGLUdU1rvcrcb5YzmWhqp5Q1UM4AWKGa/26LPt/Cun58iuISEWgO/CIiKzBCSLBQB3X9j+qata8+uCkJflaVU+qagJO4rfLzlHH7sCtrvMsw0l9UB8nWH2qqqmquhdY4Nq+EbBD/+6q+jTLsdzV+VfgUREZA1yoqqfd1CMNpyUA8DHQSZwMvh2AL1zHHA/UyLDPF6qaeo7rc+d3zdzVtltVf8l47gIc0xQhdg/CFLbEDO9TgbKu9yn83eUZnMs+aRmW08j8Gc6aN0Zx0h3fqKpbMhaISDucv4DdcZci+VwEGKmqP2Q5Ty839TrXOdzWGdgkIstwJkD6QUTuVNUF2XfPRHF+rnGqGp3DNjn9HCDD78WVBC8ol/3c/fxNMWYtCFNU7MTp2gGnC6Yg+gOISCecCWPigR+Aka4vN0SkVR6Osxi4zpUZNBS4Hlhyjn1+AO4RJ6U6ItLAte9inGya/uKkYb7Stf1moK44kzel1z3DsbLVWUTq4rQ63sDJ0tnCTT38+PvndwvwszrzfsSIyE2u44iItMzhOk7gdOedtZO/fy/XAoG5/AzqiEh71/uBwM+5bGuKAQsQpqh4GecLdinOPYiCOOba/12cDJcAT+N8qa0V5zHMp891EHWmZp2MkxZ5GfCeqq4+x27v4aTUXuU6z3ic1s3XOBk21wHjgJ9c5ziN80TUHBH5GTiA032WW537A+td3USNgI/c1OMk0FREVgJdgP+41g8C7hCRP3DuqeQ0te4M4PqzN6mBicAVIvI7zr2L3Fobm4DbRGQtUNl1vaYYs2yuxviIiJRT1QRXS+FtYKuq/u88j5mgquU8U0NT2lkLwhjf+YerNbABCMNpdRhTZFgLwhhjjFvWgjDGGOOWBQhjjDFuWYAwxhjjlgUIY4wxblmAMMYY49b/A9qUDTw7RwYnAAAAAElFTkSuQmCC\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.7, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "a9580470",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7316\n",
      "0.0024166091947189165\n",
      "\n"
     ]
    }
   ],
   "source": [
    "index_cora = np.where(acc2_cora == min(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": 40,
   "id": "d82d8f0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_cora = pd.DataFrame([acc_cora[0:num], acc2_cora[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_cora['number of edges to be removed'] = df_cora.index\n",
    "df_cora.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_cora.to_csv('visulize/attack_on_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "474b79e6",
   "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>Unnamed: 0</th>\n",
       "      <th>test accuracy</th>\n",
       "      <th>val_accuracy</th>\n",
       "      <th>SGC</th>\n",
       "      <th>Best accuracy reported in paper</th>\n",
       "      <th>number of edges to be removed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.792</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.799</td>\n",
       "      <td>0.788</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.795</td>\n",
       "      <td>0.786</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.795</td>\n",
       "      <td>0.786</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.794</td>\n",
       "      <td>0.786</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>95</td>\n",
       "      <td>0.732</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>96</td>\n",
       "      <td>0.732</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>97</td>\n",
       "      <td>0.732</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>98</td>\n",
       "      <td>0.728</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>99</th>\n",
       "      <td>99</td>\n",
       "      <td>0.727</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>99</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>100 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Unnamed: 0  test accuracy  val_accuracy   SGC  \\\n",
       "0            0          0.804         0.792  0.81   \n",
       "1            1          0.799         0.788  0.81   \n",
       "2            2          0.795         0.786  0.81   \n",
       "3            3          0.795         0.786  0.81   \n",
       "4            4          0.794         0.786  0.81   \n",
       "..         ...            ...           ...   ...   \n",
       "95          95          0.732         0.720  0.81   \n",
       "96          96          0.732         0.720  0.81   \n",
       "97          97          0.732         0.720  0.81   \n",
       "98          98          0.728         0.720  0.81   \n",
       "99          99          0.727         0.720  0.81   \n",
       "\n",
       "    Best accuracy reported in paper  number of edges to be removed  \n",
       "0                              0.83                              0  \n",
       "1                              0.83                              1  \n",
       "2                              0.83                              2  \n",
       "3                              0.83                              3  \n",
       "4                              0.83                              4  \n",
       "..                              ...                            ...  \n",
       "95                             0.83                             95  \n",
       "96                             0.83                             96  \n",
       "97                             0.83                             97  \n",
       "98                             0.83                             98  \n",
       "99                             0.83                             99  \n",
       "\n",
       "[100 rows x 6 columns]"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.read_csv('visulize/attack_on_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "c55e2290",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEWCAYAAAB8LwAVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABN/0lEQVR4nO3deVhV1frA8e/LDAqo4ASoOI8oKs6ZY2rmkGWpqaUNZjZc69Zt/mVz9zbZaJmpZVaajZqVaZqm5pjzPIszKggo8/r9sY94gAMckCMC7+d5zsPZw9p77SOel7XW3u8SYwxKKaVUdm7FXQGllFJXJw0QSimlHNIAoZRSyiENEEoppRzSAKGUUsohDRBKKaUc0gCh1GUQkeki8lJZO7cqGzRAKKWUckgDhFJKKYc0QCgFiMgBEXlSRLaJyFkRmSYiPiIySkT+yravEZF6dquCReR3EYkXkT9FpFa2fceJyG7b9hdFpK6IrBSRcyIyW0S87PbvJyIbRCRWRFaISHO7bS1FZL3tOLMAH1d+JkppgFDqkuFAb6Au0AB4pgDlXgSCgQ3AzGzb+wCtgfbAf4DJtjI1gGbAMAARaQVMBe4FgoCPgZ9ExNsWRH4AZgCVgG+Amwt+iUo5TwOEUpe8b4w5bIw5A7yM7YvbCT8bY5YaY5KBp4EOIlLDbvt/jTHnjDFbgS3AAmPMPmNMHPAL0NK23z3Ax8aYVcaYdGPMZ0AyVmBpD3gCE40xqcaYOcCay71gpfKiAUKpSw7bvT8IhBS0nDEmATiTrewJu/cXHCyXt72vBfzb1r0UKyKxWK2MENvriMmaXfOgk/VTqlA0QCh1if1f/TWBo0Ai4HdxpYhUy6uciJTH6gI6WojzHwZeNsZUsHv5GWO+Ao4BoSIi2eqolMtogFDqkvtFJExEKgFPAbOAjUBTEYkUER9ggoNyfUXkGts4wYvAKmPMYQf75ecTYKyItBNLORG5QUT8gZVAGvCQiHiIyE1A20KcQymnaYBQ6pIvgQXAPtvrJWPMLuAFYCGwG/grl3LPYXUttcYagC4wY8xarHGI94GzwB5glG1bCnCTbfksMAT4rjDnUcpZohMGKWXd5grcbYxZWNx1UepqoS0IpZRSDmmAUEop5ZB2MSmllHJIWxBKKaUc8ijuChSl4OBgEx4eXtzVUEqpEmPdunUxxpjKjraVqgARHh7O2rVri7saSilVYohIrk/kaxeTUkophzRAKKWUckgDhFJKKYdK1RiEI6mpqURHR5OUlFTcVVF2fHx8CAsLw9PTs7iropTKRakPENHR0fj7+xMeHk7WRJiquBhjOH36NNHR0dSuXbu4q6OUykWp72JKSkoiKChIg8NVREQICgrSVp1SV7lSHyAADQ5XIf03UerqVyYChFJKqYLTAOFisbGxfPjhh4UuP3HiRM6fP1+ENVJKKedogHCx0hAg0tLSivX8Sqni4dIAISJ9RGSniOwRkSccbA8UkbkislFEtorI6Gzb3UXkHxGZ58p6utITTzzB3r17iYyM5LHHHgPg9ddfp02bNjRv3pznnnsOgMTERG644QZatGhBs2bNmDVrFu+++y5Hjx6lW7dudOvWLcexX3jhBdq0aUOzZs0YM2YMFzPz7tmzh549e9KiRQtatWrF3r17Afjf//5HREQELVq04IknrH+Orl27ZqYniYmJ4WIuq+nTp3PLLbfQv39/evXqRUJCAj169KBVq1ZERETw448/Ztbj888/p3nz5rRo0YKRI0cSHx9P7dq1SU1NBeDcuXOEh4dnLiulSgaX3eYqIu7AB8B1QDSwRkR+MsZss9vtfmCbMaa/iFQGdorITNv0igD/ArYDAUVRp+fnbmXb0XNFcahMTUICeK5/01y3v/baa2zZsoUNGzYAsGDBAnbv3s3q1asxxjBgwACWLl3KqVOnCAkJ4eeffwYgLi6OwMBA3nrrLRYvXkxwcHCOYz/wwAP83//9HwAjR45k3rx59O/fn+HDh/PEE08waNAgkpKSyMjI4JdffuGHH35g1apV+Pn5cebMmXyvbeXKlWzatIlKlSqRlpbG999/T0BAADExMbRv354BAwawbds2Xn75ZZYvX05wcDBnzpzB39+frl278vPPP3PjjTfy9ddfc/PNN+szD0qVMK5sQbQF9hhj9tm+8L8GBmbbxwD+Yt3SUh5rTt80ABEJA24ApriwjlfcggULWLBgAS1btqRVq1bs2LGD3bt3ExERwcKFC3n88cdZtmwZgYGB+R5r8eLFtGvXjoiICP744w+2bt1KfHw8R44cYdCgQYD1QJqfnx8LFy5k9OjR+Pn5AVCpUqV8j3/ddddl7meM4amnnqJ58+b07NmTI0eOcOLECf744w8GDx6cGcAu7n/33Xczbdo0AKZNm8bo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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_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.7, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "b21d9758",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_pubmed = pd.DataFrame([acc_pubmed[0:num], acc2_pubmed[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_pubmed['number of edges to be removed'] = df_pubmed.index\n",
    "df_pubmed.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_pubmed.to_csv('visulize/attack_on_accuracy/pubmed.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "52fc1386",
   "metadata": {},
   "outputs": [],
   "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": 45,
   "id": "ec12fd4a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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evQoYWFhvPHGGyxcuJDy5ctnuvfw4cN55plnALjtttuYNWsWPXr04JZbbmHkyJH07t2bU6dOkZKSwg8//MA333zD8uXLCQ0N5dChQ2es27Jly1izZg1ly5YlKSmJGTNmUKpUKQ4cOMBll11Gz5492bBhAy+99BK//PIL5cuX59ChQ5QsWZL27dvz/fffc8MNNzB16lRuuukme2bDmPOMtTgKiHnz5jFv3jyaN2/OpZdeyl9//cWWLVto0qQJP/74I48//jhLly4lLCzsjPdauHAhbdq0oUmTJvz000+sX7+e48ePs2vXLnr37g04D9qFhoby448/cueddxIaGgpA2bJlz3j/a6+9Ni2dqvLkk0/StGlTOnXqxK5du9i7dy8//fQTffr0SQtsqenvueceJk6cCMDEiRO58847vb+JMabAshYHZNsyOFdUlSeeeIIhQ4ZkurZq1Spmz57NE088QefOndNaE96cOnWK++67j5UrV1K9enVGjRrFqVOnyGqFAFX1OgU2KCiIlJSUtHt6Kl68eNrrKVOmsH//flatWkVwcDA1a9ZMez9v923Xrh1RUVEsXryY5ORkGjdunGVdjDEFk7U48knJkiU5fvx42nGXLl2YMGECsbGxAOzatYt9+/YRExNDaGgot956K48++iirV6/2mj9V6od8+fLliY2NZfr06QCUKlWKatWq8c033wAQHx9PXFwcnTt3ZsKECWkD7aldVTVr1mTVqlUAaffw5ujRo1SsWJHg4GAWLlzI3387qzB37NiRadOmcfDgwXT3Bbj99tsZOHCgtTaMOU9ZiyOflCtXjnbt2tG4cWO6devGq6++ysaNG2nbti0AJUqU4NNPP2Xr1q089thjBAQEEBwczJgxYwAYPHgw3bp1o0qVKixcuDDtvqVLl+bee++lSZMm1KxZk1atWqVdmzx5MkOGDOGZZ54hODiYL7/8kq5duxIZGUnLli0pUqQI1113HS+//DKPPvoo/fr1Y/LkyVxzzTVZ1uOWW26hR48etGzZkoiICFI3zGrUqBFPPfUUV199NYGBgTRv3pxJkyal5Xn66acZOHBgXv9YjTHnQKFd5HDjxo1ccskl+VSiwm369OnMnDmTyZMne71u/zbGFAy2yKEpEB544AF++OEHZs+end9FMcacJQsc5pz63//+l99FMMbkkg2OG2OM8YkFDmOM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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.6, 0.8)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "d8e058ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_citeseer = pd.DataFrame([acc_citeseer[0:num], acc2_citeseer[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_citeseer['number of edges to be removed'] = df_citeseer.index\n",
    "df_citeseer.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_citeseer.to_csv('visulize/attack_on_accuracy/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "38070e9e",
   "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>Unnamed: 0</th>\n",
       "      <th>test accuracy</th>\n",
       "      <th>val_accuracy</th>\n",
       "      <th>SGC</th>\n",
       "      <th>Best accuracy reported in paper</th>\n",
       "      <th>number of edges to be removed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.719</td>\n",
       "      <td>0.738</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.736</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.718</td>\n",
       "      <td>0.728</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.722</td>\n",
       "      <td>0.724</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.718</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>95</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.646</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>96</td>\n",
       "      <td>0.647</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>97</td>\n",
       "      <td>0.647</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>98</td>\n",
       "      <td>0.648</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>99</th>\n",
       "      <td>99</td>\n",
       "      <td>0.648</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>99</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>100 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Unnamed: 0  test accuracy  val_accuracy   SGC  \\\n",
       "0            0          0.719         0.738  0.81   \n",
       "1            1          0.720         0.736  0.81   \n",
       "2            2          0.718         0.728  0.81   \n",
       "3            3          0.722         0.724  0.81   \n",
       "4            4          0.718         0.720  0.81   \n",
       "..         ...            ...           ...   ...   \n",
       "95          95          0.650         0.646  0.81   \n",
       "96          96          0.647         0.650  0.81   \n",
       "97          97          0.647         0.650  0.81   \n",
       "98          98          0.648         0.650  0.81   \n",
       "99          99          0.648         0.650  0.81   \n",
       "\n",
       "    Best accuracy reported in paper  number of edges to be removed  \n",
       "0                              0.83                              0  \n",
       "1                              0.83                              1  \n",
       "2                              0.83                              2  \n",
       "3                              0.83                              3  \n",
       "4                              0.83                              4  \n",
       "..                              ...                            ...  \n",
       "95                             0.83                             95  \n",
       "96                             0.83                             96  \n",
       "97                             0.83                             97  \n",
       "98                             0.83                             98  \n",
       "99                             0.83                             99  \n",
       "\n",
       "[100 rows x 6 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.read_csv('visulize/attack_on_accuracy/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d0a6197f",
   "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": "718dd8ab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0, 2, 3]),)"
      ]
     },
     "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": "98e9c652",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.712"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc2_citeseer[20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "7eb8be84",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.758"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "563b37e8",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "eeaaab28",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:07<00:00,  6.73it/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": "46a53f4f",
   "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_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": "6f1756b8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8042500000000001\n",
      "0.0011989578808281809\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": "be10f3c9",
   "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": "66c84d80",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:03<00:00, 14.65it/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": "1730243d",
   "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": "a42b8dba",
   "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": "4ad5626f",
   "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
}
