{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d7619ba9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n",
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "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": 5,
   "id": "f5e2aef2",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.01\n",
    "\n",
    "num_layer = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ec5a3cb8",
   "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": 7,
   "id": "a68fc1e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl = pd.read_csv('result_data/edge_influence_new_version.csv')\n",
    "total_edges = cora_infl.shape[0]\n",
    "cora_infl = cora_infl.loc[cora_infl['influence'] > 0]\n",
    "cora_infl = cora_infl.sort_values(['influence'], ascending=False)\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "333ec977",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = cora_infl.shape[0]\n",
    "i = 2\n",
    "\n",
    "acc_cora = []\n",
    "acc2_cora = []\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b175be9b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 1680/1680 [03:12<00:00,  8.75it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_cora = cora_infl.loc[0:i]['from_edges'].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i]['to_edges'].values.astype(int)\n",
    "\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",
    "    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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d20a2aaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "df1 = pd.DataFrame([acc2_cora, acc_cora]).T\n",
    "df1.columns = ['validate acc', 'test acc']\n",
    "df1.to_csv('drop_acc/cora_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "aa81d36b",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl.to_csv('drop_acc/cora_edge_influence_positive_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "cd07440a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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FkVFRdxzzz2WbYqiWG7FpKen07ZtW8u+Ro0aWR1bWlpqFduVr5OSkjhw4IDlNhGYk86gQYMAeO+99/jwww958803CQ0N5amnnqJjx47lxunr62vVh3P580tOTqa0tJSePXta9plMJqs4/Pz8rvk52KK8n8GV2xo1anRdvz+i+kkCEbXC0dHRqh/g4sWL/7rOK6cuT05OxsfHBzB/CT3yyCNMmjTpqsdW1AHu4+NDcnJymXP16tXrmjF5enri4ODA999/j6+vb7l1/zPuy7y8vNBqtaSmptK0aVPLeS/z9/ena9euLFmypNxzt2vXjg8//BCDwcCXX37JE088wdatW8stm5aWhqIols8hJSWF8PBw/Pz8sLOzY8eOHWi15X9d/POzK++zdHR0pKioyPI+IyPjmvVcjqNFixaA9c9U1A1yC0vUilatWnH8+HGOHDlCSUkJ77///r+u86uvviI1NZWcnBw++ugjBg4cCMDw4cP53//+x/79+1EUhcLCQn755Rfy8/NtqvfOO+/kzJkzxMbGUlpayvr16zlx4gS9e/e+5rFqtZrhw4czb948MjMzAfOX9a+//gpAZGQka9as4cSJExQVFfHBBx9YjtVoNPTr148PPviAoqIiTp48ybp16yz7e/fuzZkzZ1i7di0GgwGDwcCBAwc4efIker2e7777jry8PHQ6Hc7OzpblS8uTlZXFsmXLMBgM/PDDD5w8eZI777wTHx8fbr/9dl599VXy8/MxmUycO3eOXbt2XbUub29v0tLS0Ov1lm1hYWH89NNPFBUVcfbs2TIPC1zNp59+Sm5uLikpKSxbtszyMxV1gyQQUSuaNm3Ko48+yrhx4+jfvz+dO3f+13VGRUUxfvx4+vbtS1BQkOWK45ZbbmHu3Lm8+OKLdO3alf79+7N69Wqb6/X09GTRokUsWbKE7t2788knn7Bo0SKbF9955plnaNKkCSNGjKBTp06MGzeO06dPA+bkNHbsWMaOHUu/fv3o0aOH1bEzZ84kLy+P22+/nWeffZa7777bshiWi4sLn376KevXr6dXr1707NmTN954w/LFvW7dOsLDw+nUqRP/+9//KlzOtl27dpw9e5YePXrwzjvv8N577+Hp6QnAa6+9hsFgsDzh9vjjj1d4xdijRw+aN29Oz5496d69O4Clf+W2225j6tSpREdH2/TZRUREcM899zB48GB69+7NsGHDbDpO1AxZD0SIeuT1118nIyOD+fPnV1mdMvBPVJZcgQhRh508eZKjR4+iKAoHDhxg5cqV9OvXr7bDEgKQTnQh6rSCggKeeuop0tPT8fb2Zvz48URERNR2WEIAcgtLCCFEJcktLCGEEJUiCUQIIUSlSAIRQghRKZJAhBBCVIokECGEEJUiCUQIIUSl/D/DVRLLCH6vwQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 500\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": null,
   "id": "ae9ff5b0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b4b5bd7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "from typing import Dict\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "sns.set_theme()\n",
    "sns.set_style(\"whitegrid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d02c3982",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2.76441945, 1.8861695 , 1.53591485, 1.16176015, 1.14125502,\n",
       "       1.10409871, 0.96057004, 0.92571448, 0.90736099, 0.88832908,\n",
       "       0.83444756, 0.81953647, 0.81786304, 0.78302435, 0.75669753,\n",
       "       0.72336088, 0.68667715, 0.68061339, 0.64877823, 0.63476237,\n",
       "       0.58788834, 0.58221988, 0.57991973, 0.57679167, 0.56334195,\n",
       "       0.56061511, 0.5274406 , 0.51641539, 0.4723759 , 0.4692292 ,\n",
       "       0.46590185, 0.4409563 , 0.43394664, 0.43129056, 0.42279688,\n",
       "       0.41337932, 0.39861157, 0.39631316, 0.38435186, 0.38023243,\n",
       "       0.37497114, 0.37404814, 0.37162426, 0.37050125, 0.3683433 ,\n",
       "       0.36677221, 0.34819458, 0.3442105 , 0.33916694, 0.33506063])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "infl_edges = cora_infl.loc[0:i]['influence'].values\n",
    "infl_edges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e086c835",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_acc_drop(acc_low_limit = 0.73, acc_up_limit = 0.83)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "5b1b4d5f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([2.76441945, 1.8861695 , 1.53591485, 1.16176015, 1.14125502,\n",
       "       1.10409871, 0.96057004, 0.92571448, 0.90736099, 0.88832908,\n",
       "       0.83444756, 0.81953647, 0.81786304, 0.78302435, 0.75669753,\n",
       "       0.72336088, 0.68667715, 0.68061339, 0.64877823, 0.63476237,\n",
       "       0.58788834, 0.58221988, 0.57991973, 0.57679167, 0.56334195,\n",
       "       0.56061511, 0.5274406 , 0.51641539, 0.4723759 , 0.4692292 ,\n",
       "       0.46590185, 0.4409563 , 0.43394664, 0.43129056, 0.42279688,\n",
       "       0.41337932, 0.39861157, 0.39631316, 0.38435186, 0.38023243,\n",
       "       0.37497114, 0.37404814, 0.37162426, 0.37050125, 0.3683433 ,\n",
       "       0.36677221, 0.34819458, 0.3442105 , 0.33916694, 0.33506063])"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "infl_edges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "ae9f1496",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plt' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_58072/3774955586.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0my_up_limit\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0.83\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      9\u001b[0m \u001b[0my_low_limit_2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my_up_limit_2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m3\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m \u001b[0mfig\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0max\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msubplots\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfigsize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m8\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgridspec_kw\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m{\u001b[0m\u001b[0;34m'height_ratios'\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m3\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mconstrained_layout\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     11\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0max\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_ylabel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Infl.'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plt' is not defined"
     ]
    }
   ],
   "source": [
    "num = 100\n",
    "x_low_limit = 0\n",
    "x_up_limit = 50\n",
    "\n",
    "sep = 4\n",
    "\n",
    "y_low_limit = 0.73\n",
    "y_up_limit = 0.83\n",
    "y_low_limit_2, y_up_limit_2 = 0, 3\n",
    "fig, ax = plt.subplots(2, 1, figsize=(10, 8), gridspec_kw={'height_ratios': [1, 3]}, constrained_layout=True)\n",
    "\n",
    "ax[0].set_ylabel('Infl.')\n",
    "ax[0].bar(x, infl_edges, label = 'test accuracy', color = '#446CCF')\n",
    "ax[0].set_ylim(y_low_limit_2, y_up_limit_2)\n",
    "ax[0].set_xlabel('Edge Index sorted by Infl.', loc=\"center\", size = 12)\n",
    "ax[0].set_xlim(x_low_limit-0.5, x_up_limit)\n",
    "grid_x_ticks = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks = np.arange(y_low_limit_2, y_up_limit_2, (y_up_limit_2 - y_low_limit_2) / sep)\n",
    "\n",
    "ax[0].set_xticks(grid_x_ticks , minor=True)\n",
    "ax[0].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "ax[0].grid(which='both')\n",
    "\n",
    "ax[0].grid(which='minor', alpha=1, linestyle='-')\n",
    "\n",
    "\n",
    "\n",
    "ax[1].plot(x, acc_cora[0:num], linestyle='solid', color='firebrick', linewidth=3, label = 'test accuracy')\n",
    "ax[1].plot(x, acc2_cora[0:num], linestyle='solid', color='royalblue', linewidth=3, label = 'val accuracy')\n",
    "ax[1].axhline(y=0.804, color='green', linestyle='--',linewidth=3, label = 'SGC')\n",
    "ax[1].set_xlim(x_low_limit, x_up_limit)\n",
    "ax[1].set_ylim(y_low_limit, y_up_limit)\n",
    "# fig.supxlabel('Number edges')\n",
    "ax[1].set_ylabel('Acc.')\n",
    "\n",
    "ax[1].set_xlabel('Num. Edges removed', loc=\"center\", size = 12)\n",
    "\n",
    "\n",
    "grid_x_ticks_2 = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks_2 = np.arange(y_low_limit, y_up_limit, (y_up_limit - y_low_limit) / 13)\n",
    "\n",
    "ax[1].set_xticks(grid_x_ticks_2 , minor=True)\n",
    "ax[1].set_yticks(grid_y_ticks_2 , minor=True)\n",
    "\n",
    "ax[1].grid(which='both')\n",
    "\n",
    "ax[1].grid(which='minor', alpha=1, linestyle='-')\n",
    "ax[1].legend(loc = (0.03, 0.03), prop={'size': 15})\n",
    "\n",
    "\n",
    "fig.suptitle('Cora: removing high influential edges', x = 0.55)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "cceac00a",
   "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████| 10674/10674 [13:29<00:00, 13.18it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "data_set_2 = 'pubmed'\n",
    "l2_term = 0.004\n",
    "num_layer = 2\n",
    "\n",
    "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)\n",
    "\n",
    "pubmed_infl = pd.read_csv('result_data/pubmed_edge_influence_new_version.csv')\n",
    "pubmed_infl = pubmed_infl.loc[pubmed_infl['predicted_influence'] > 0]\n",
    "pubmed_infl = pubmed_infl.sort_values(['predicted_influence'], ascending=False)\n",
    "pubmed_infl.index = range(len(pubmed_infl))\n",
    "\n",
    "n = pubmed_infl.shape[0]\n",
    "i = 2\n",
    "\n",
    "acc_pubmed = []\n",
    "acc2_pubmed = []\n",
    "\n",
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i]['from_edges'].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i]['to_edges'].values.astype(int)\n",
    "\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",
    "    \n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, 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))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "3518f925",
   "metadata": {},
   "outputs": [],
   "source": [
    "df2 = pd.DataFrame([acc2_pubmed, acc_pubmed]).T\n",
    "df2.columns = ['validate acc', 'test acc']\n",
    "df2.to_csv('drop_acc/pubmed_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a365d198",
   "metadata": {},
   "outputs": [],
   "source": [
    "infl_edges = pubmed_infl.loc[0:99]['predicted_influence'].values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "61c83c4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "pubmed_infl.to_csv('drop_acc/pubmed_edge_influence_positive_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "c397df00",
   "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>actual_influence</th>\n",
       "      <th>predicted_influence</th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.670028</td>\n",
       "      <td>2.167824e+00</td>\n",
       "      <td>10820</td>\n",
       "      <td>17239</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.734669</td>\n",
       "      <td>1.872085e+00</td>\n",
       "      <td>8574</td>\n",
       "      <td>8574</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.343842</td>\n",
       "      <td>1.863053e+00</td>\n",
       "      <td>3508</td>\n",
       "      <td>3508</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2.208691</td>\n",
       "      <td>1.734238e+00</td>\n",
       "      <td>16972</td>\n",
       "      <td>19249</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.378000</td>\n",
       "      <td>1.491624e+00</td>\n",
       "      <td>9783</td>\n",
       "      <td>16359</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>10669</th>\n",
       "      <td>0.024432</td>\n",
       "      <td>9.761284e-07</td>\n",
       "      <td>13532</td>\n",
       "      <td>13532</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10670</th>\n",
       "      <td>0.012323</td>\n",
       "      <td>8.902100e-07</td>\n",
       "      <td>19397</td>\n",
       "      <td>19648</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10671</th>\n",
       "      <td>-0.012932</td>\n",
       "      <td>7.199768e-07</td>\n",
       "      <td>10879</td>\n",
       "      <td>11698</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10672</th>\n",
       "      <td>0.038549</td>\n",
       "      <td>5.702787e-07</td>\n",
       "      <td>10950</td>\n",
       "      <td>16717</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10673</th>\n",
       "      <td>0.013576</td>\n",
       "      <td>1.741037e-07</td>\n",
       "      <td>10671</td>\n",
       "      <td>16469</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10674 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       actual_influence  predicted_influence  from_edges  to_edges\n",
       "0              2.670028         2.167824e+00       10820     17239\n",
       "1              1.734669         1.872085e+00        8574      8574\n",
       "2              2.343842         1.863053e+00        3508      3508\n",
       "3              2.208691         1.734238e+00       16972     19249\n",
       "4              1.378000         1.491624e+00        9783     16359\n",
       "...                 ...                  ...         ...       ...\n",
       "10669          0.024432         9.761284e-07       13532     13532\n",
       "10670          0.012323         8.902100e-07       19397     19648\n",
       "10671         -0.012932         7.199768e-07       10879     11698\n",
       "10672          0.038549         5.702787e-07       10950     16717\n",
       "10673          0.013576         1.741037e-07       10671     16469\n",
       "\n",
       "[10674 rows x 4 columns]"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pubmed_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "f1cb277e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.55, 0.98, 'pubmed: removing high influential edges')"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Zznv+65du3biOrlcDm9vb6SnpwPQ7/vX09MTPXv2hL+/P7p3747OnTtj0KBBcHV1LcOVIar5GLCJ6jihQD2nRCIptE67frIsCo50IZFIinyAMG9UiLzzfvvtt2JI12ZjY1OuWuuSyGQymJiYiMt5x//tt99gZmams612aAAKf76i1hW8ngWPkXfOvPUymQz+/v7Ys2cP3n77bezevRutWrXSCe5FKXhdtc+b99+izq2Pko5d1GfR91zFPUxa1lFCytK+4kilmopJ7f1UKpVOW9RqNdzd3XXKlfIUDNgl3ef6+umnn7Bu3ToEBASgdevWsLCwwKZNm3Ds2DG9j6HP/ax9/5WmpO30+f6VyWTYsGEDrl+/jtOnT+PQoUP46quv8O2336Jfv356tYHoWcAabKI65vr16zoPqF25cgVyuRyNGjUCADg4OCAmJkZnn6IeQHrw4AHS0tLE5cuXLwPQ9CaWV/PmzWFiYoInT56gcePGhf7JZDK0aNFC53yApgfx+vXr5T6vttatWwMAIiMjC50/7xqVV/PmzXH//n2dh0Hj4uLw6NEjNG/eXFw3cuRI3L17F9evX0dwcDBGjBhRofNaWVnByclJ55oBwNWrVyt03Oo+lyHl9aRr3/u3bt3SCdze3t548uQJLC0tC90bZRmdJC98lxa4L1y4gF69emHUqFFo1aoVGjduLD4Qqy997ucWLVogISEBjx49EvcruJx3f165ckVcl5OTo1Onrc/3L6AJ6W3btsU777yDX375Bc8991yZ68qJajoGbKI6JikpCYsWLcKDBw/w77//4ttvv8Xo0aNhbm4OAOjevTv+++8/7N+/H48fP8YPP/yACxcuFDqORCLBxx9/jLt37+L8+fP47LPP0Ldv3yJ7rvRlYWGBKVOm4Ouvv8bWrVvx8OFD3Lt3D/v27RNLJBo3bgxfX1989tlnOHPmDO7fv4958+aJf6bO8/fff2PIkCGIjo4uUxsaN26Ml156CZ9++il2796Nx48f4/bt29ixYwd++OGHcn82APD394e9vT1mzpyJmzdv4saNG5g5cyacnZ0xdOhQcTsPDw+0atUKn376KRITE+Hn51eh8wLAm2++ic2bN2Pv3r149OgRNm3ahFOnTpW7V7umnMtQGjdujPr162PVqlV48OABLly4gM8//1ynzcOGDUODBg0wefJknDx5Ek+f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4NChQ4iLi8Mbb7wBW1tb7Nu3D5MmTcKMGTPQpk0bfP3117h58yakUinkcjmWLVsGR0fH6m46EREREVEh1R6w582bh3nz5hVav379evF1YGBgVTaJiIiIiKjcnokSESIiIiKiZwUDNhERERGRATFgExEREREZEAM2EREREZEBMWCXQd5kM5x0hoiIiIiKw4BdBnkTz3DSGSIiIiIqDpMiEREREZEBMWCXk3aZCEtGiIiIiCgPA3Y55ZWLDJx+RWc9wzYRERFR3VbtMznWBnlhGwD+XtW+WttCRERERNWLPdhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAZUqQH74sWLlXl4IiIiIqIap1ID9ttvv12ZhyciIiIiqnEqNWBfvny5Mg9PRERERFTjsAbbwBRKtc7rvGXt9URERERUexmVd8dZs2ZBIpGUut2yZctKfD8wMBAHDx5EeHg4goKC4OHhUWgblUqFJUuW4MSJE5BIJJg8eTJGjRpV3qZXKmO5FAOnXwEA/L2qPQBg4PQr4msiIiIiqt3KHbAbN25skAb0798fEydOxLhx44rdJigoCGFhYTh06BCSkpIwYsQIdOvWDQ0aNDBIG4iIiIiIDKXcATs9PR2zZ88GAPz333/o1q1buY7TqVOnUrfZv38/Ro0aBalUCnt7ewwYMAAHDhx45h6iVCjVMJZLC70mIiIiotqj3Anvjz/+EF9PmzbNII0pTmRkJNzc3MRlV1dXREVFVeo5K0Ne+cjA6VcYromIiIhqqXL3YLds2RIzZsyAu7s7FAoFvv322yK3e//998vduNqMvdlEREREtVO5A/bKlSuxbds2REREAECl9ii7uroiIiICbdu2BVC4R/tZpP0w5L6v24rrGbaJiIiInm3lDtgODg6YOnUqAM0oH59//rnBGlXQkCFDsH37dgwaNAhJSUk4fPgwfvnll0o7X1UrauQRIiIiIno2lTtga8sL1/Hx8cjIyNB5r2HDhiXuu2TJEhw6dAhxcXF44403YGtri3379mHSpEmYMWMG2rRpg+HDh+Pq1asYNGgQAE3Nd2nHJSIiIiKqDgYJ2CdOnMAnn3yC2NhYnfUSiQS3bt0qcd958+Zh3rx5hdavX79efC2TybBo0SJDNJWIiIiIqFIZJGAvWrQIU6dOxciRI2FqamqIQxIRERERPZMMErBTUlIwZswYvWZ2JCIiIiKqzQwyXMVLL72EnTt3GuJQBM1IItr/JSIiIqJnh0F6sK9evYotW7Zg/fr1qFevns57tWm0j6qSN6rI36vac7xsIiIiomeMQQL2qFGjMGrUKEMcigrgEH5EREREz5YKBez//vsPAODi4mKQxhARERERPesqFLDnzp1b4vsSiQRHjhypyCmIiIiIiJ4pFQrYR48eNVQ7SA+sxyYiIiKq+ZjQniF59dh5Ndl5ONoIERERUc1hkIccqerx4UciIiKimok92EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYtUTebI6c1ZGIiIioejFg1xJ5Mzsay/klJSIiIqpONWKq9NDQUAQEBCApKQm2trYIDAxEkyZNdLZZtWoVfv31Vzg5OQEAOnbsiAULFlRDa2s+hVItBm3t10RERERU+WpEwF6wYAHGjh2L4cOHY8+ePZg/fz5+/vnnQtuNGDECs2fProYWPlvyerMBYN/XbcX1DNtEREREla/a01Z8fDxCQkLg5+cHAPDz80NISAgSEhKquWW1Q17YZvkIERERUdWo9sQVGRkJZ2dnyGQyAIBMJoOTkxMiIyMLbbtv3z74+/vjzTffxOXLl6u6qUREREREpaoRJSL6GDNmDN555x3I5XKcOnUKU6dOxf79+2FnZ1fdTSMiIiIiElV7D7arqyuio6OhUqkAACqVCjExMXB1ddXZztHREXK5HADQo0cPuLq64t69e1Xe3med9nB+HNqPiIiIyPCqPWA7ODjAy8sLwcHBAIDg4GB4eXnB3t5eZ7vo6Gjx9a1btxAeHo6mTZtWaVtrA+3h/LRfa4dsBm4iIiKi8qsRJSILFy5EQEAA1qxZA2trawQGBgIAJk2ahBkzZqBNmzb4+uuvcfPmTUilUsjlcixbtgyOjo7V3PLagyOPEBERERlGjQjY7u7u2L59e6H169evF1/nhW6qfNph++9V7au1LURERETPGnZNUqlYq01ERESkPwZsKlVRtdraD0kCQLaCNdxEREREAAM2lVFRD0kOnH4FJsa6E9qw15uIiIjqKgZsqhTF9XoTERER1XYM2FTpihsOkGUlREREVBvViFFEqO4oOEIJRyshIiKi2oY92FRjsJSEiIiIagMGbKox9BmthOGbiIiIajoGbKqRihutRJt2+C7udd4yERERUVVhwKZninbY1g7fxb0uLZQTERERGRoDNtV6JYVyfSfO0aennKOiEBEREcCATXWcvhPn6NNTXtJkO+UJ8kRERPRsYsAmqiTlCeX6jBmuT+96UdsRERFR1WDAJqqhigvi+vSuF9xOm76hXN8gz/BORESkiwGbqA7Q5+HQ8gZ5beXtXS+unIaIiOhZxIBNRBVS1tr1stS4G/rBUz6sSkREVYEBm4hqLEM/eFodD6vyAVciorqHAZuIqARVFeSravhIQ9bf8+FbIqKiMWATEdUwVRXkDfkgbU17+NYQ4Z9lSERUXgzYRERULSrz4duK7lPby5Bq8j5EtUGNCNihoaF45ZVXMHjwYLzyyit49OhRoW1UKhUWLVqEAQMGYODAgdi+fXvVN5SIiMjAqqMMqSbvU91/vajJ+zxLvyjV5H2qQo0I2AsWLMDYsWNx8OBBjB07FvPnzy+0TVBQEMLCwnDo0CFs27YNq1atwtOnT6uhtURERFRZqvuvFzV5n2fpF6WavE9xodyQ4bvaA3Z8fDxCQkLg5+cHAPDz80NISAgSEhJ0ttu/fz9GjRoFqVQKe3t7DBgwAAcOHKiOJhMRERHRM6q4UG4sN1wsNjLYkcopMjISzs7OkMlkAACZTAYnJydERkbC3t5eZzs3Nzdx2dXVFVFRUXqdQxAEAIC1uea/2dnZAAA7S0Hndd57xb2uDfsUtR33qdn7FLVdbdvnWfua1LZ9itqO+zx7X8fatk9R23GfZ+/r+Kzto1AoAORnx/KSCBU9QgXduHEDs2fPxr59+8R1Q4cOxZdffonWrVuL6/z9/fG///0Pbdu2BQCsX78e0dHRmDdvXqnnSE1Nxd27dw3feCIiIiKqdTw8PGBlZVXu/au9B9vV1RXR0dFQqVSQyWRQqVSIiYmBq6troe0iIiLEgF2wR7skFhYW8PDwgFwuh0QiMfhnICIiIqJnnyAIUCqVsLCwqNBxqj1gOzg4wMvLC8HBwRg+fDiCg4Ph5eWlUx4CAEOGDMH27dsxaNAgJCUl4fDhw/jll1/0OodUKq3QbyFEREREVDeYmppW+BjVXiICAA8ePEBAQABSUlJgbW2NwMBANGvWDJMmTcKMGTPQpk0bqFQqfPbZZzh16hQAYNKkSXjllVequeVERERERLpqRMAmIiIiIqotqn2YPiIiIiKi2oQBm4iIiIjIgBiwiYiIiIgMiAGbiIiIiMiAqn2YvqoSGhqKgIAAJCUlwdbWFoGBgWjSpEl1N6tGS0xMxMcff4ywsDAYGxujcePG+Oyzz2Bvbw9fX18YGxvDxMQEAPDRRx+hV69e1dzimqm4a8V7Un9Pnz7FtGnTxOXU1FSkpaXh3LlzvBdLEBgYiIMHDyI8PBxBQUHw8PAAUPLPQ96Xuoq6hiX9bASK/56vy4q7F0u6VrwXdRV1DUv62QjwXiyopO9dg/9cFOqICRMmCLt37xYEQRB2794tTJgwoZpbVPMlJiYKZ86cEZe/+OILYc6cOYIgCEK/fv2EO3fuVFfTninFXSvek+W3ZMkSYdGiRYIg8F4syfnz54WIiIhC16ike4/3pa6irmFJPxsFgfdkUYq7F0u6VrwXdRV3DbVp/2wUBN6LBZX0vWvon4t1okQkPj4eISEh8PPzAwD4+fkhJCQECQkJ1dyyms3W1hZdunQRl9u3b4+IiIhqbFHtwXuy/BQKBYKCgvDSSy9Vd1NqvE6dOhWaFbeke4/3ZWFFXUP+bCy7oq5jSXgvFlbaNeTPxtIV971bGT8X60SJSGRkJJydnSGTyQAAMpkMTk5OiIyMLDRjJBVNrVbjt99+g6+vr7juo48+giAI8PHxwf/93//B2tq6GltYsxW8Vrwny+/o0aNwdnZG69atxXW8F/VX0r0nCALvyzIq6mcjwHuyLIq6VvwZWXZF/WwEeC8WR/t7tzJ+LtaJHmyquMWLF8Pc3Bzjx48HAPzyyy/Yu3cvdu7cCUEQ8Nlnn1VzC2suXivD2rlzp04PDa8vVaeCPxsB3pNlwWtlOAV/NgK8viUp6nvXkOpEwHZ1dUV0dDRUKhUAQKVSISYmpkx/rqrLAgMD8fjxY6xYsQJSqeaWybt2xsbGGDt2LC5dulSdTazRirpWvCfLJzo6GufPn4e/v7+4jvdi2ZR07/G+LJuifjYCvCfLorhrxXuxbIr62QjwXixOwe/dyvi5WCcCtoODA7y8vBAcHAwACA4OhpeXF//MpIdvvvkGN27cwOrVq2FsbAwAyMjIQGpqKgBAEATs378fXl5e1dnMGqu4a8V7snx27dqFPn36wM7ODgDvxfIo6d7jfam/on42Arwny6Kka8V7sWwK/mwEeC8Wp6jv3cr4uSgRBEGo3I9SMzx48AABAQFISUmBtbU1AgMD0axZs+puVo127949+Pn5oUmTJjA1NQUANGjQAAEBAZg+fTpUKhXUajXc3d0xb948ODk5VXOLa54nT54Ue614T5bd4MGDMXfuXPTu3RtAydeXgCVLluDQoUOIi4uDnZ0dbG1tsW/fvhLvPd6Xuoq6hitWrCjyZ+Pq1at5TxajqOu4du3aEq8V70VdxX0/A4V/NgL8+ViU4nLN6tWrDf5zsc4EbCIiIiKiqlAnSkSIiIiIiKoKAzYRERERkQExYBMRERERGRADNhERERGRATFgExEREREZEAM2EdVJT58+haenJ3Jycqq7KTpWrVqFjz76qLqbUak8PT3x+PHjIt+bMGECtm/fXsUtAi5evIhBgwahQ4cOOHz4cLW1g4hqBwZsIqo1fH190bZtW3To0EH8Vx1TA/v6+uL06dNVft6q8Oeff+LVV1+t7maUqqy/QK1cuRLjxo3D5cuXMWDAgEpuHRHVdkbV3QAiIkNau3YtunfvXt3NqJVqWm+/IUVERKBFixbV3QwiqiXYg01EdYJKpUJgYCC6dOmC/v3749ixYzrvP3nyBOPGjUOHDh3w+uuvY9GiRTqlGleuXMGYMWPQqVMnDBs2DGfPntXrvHk9voGBgXjuuefg6+urc+4nT55g/Pjx6NChA9544w0kJibq7F/ceS9duoQuXbogMjISAHD79m106tQJDx48KNQGQRCwdOlSdOvWDT4+PvD398fdu3cBAKmpqfj444/RtWtX9OvXD2vWrIFarRbbPmbMGCxduhSdO3fGzJkzsWDBAly5cgUdOnRAp06dAAAKhQKBgYHo27cvunfvjvnz5yMrK0s8/4YNG9CzZ0/07NkTO3bsKPWahYWF4eWXX4aPjw/effddJCUlAQAmT56MLVu26Gzr7++Pw4cPl3rMgIAALFq0CJMnT0aHDh0watQohIWFAQAGDBiAJ0+e4J133kGHDh2gUChKPR4RUUkYsImoTvjjjz/wzz//YPfu3di5cycOHDig8/5HH32Etm3b4uzZs3jvvfewZ88e8b3o6GhMmTIF7777Ls6dO4fZs2djxowZSEhI0Ovc165dQ9OmTXHmzBm8/fbbmDt3LvIm0f3oo4/QunVrnD17FlOnTsWuXbv0Om/Hjh0xZswYzJ49G1lZWZg1axY++OADuLu7Fzr/yZMnceHCBRw8eBAXLlzAihUrYGtrCwBYvHgxUlNTcfjwYWzZsgV79uzBzp07ddresGFDnD59Gl9++SUWLVqE9u3b4/Lly7hw4QIA4Msvv0RoaCh2796NQ4cOISYmBqtXrwYAHD9+HD/99BN++uknHDp0CP/991+p12v37t1YunQpTpw4ASMjIyxZsgQAMGLECOzdu1fc7vbt24iJidGZHrok+/btw3vvvYfz58+jUaNG+OabbwAAhw8fhpubG9auXYvLly/D2NhYr+MRERWHAZuIapVp06ahU6dO4r8//vgDAPDXX3/htddeg6urK2xtbTFlyhRxn4iICFy/fh0zZsyAsbExOnXqBF9fX/H9PXv2oHfv3ujTpw+kUil69OgBb2/vQr3gxXFzc8Po0aMhk8kwcuRIxMbGIi4uTjzv+++/D2NjY7GHW9/zvvfee0hLS8OoUaPg5OSEcePGFXl+IyMjpKen4+HDhxAEAe7u7nBycoJKpcL+/fvx4YcfwtLSEg0aNMAbb7yhE2KdnJwwYcIEGBkZwdTUtNCxBUHA9u3b8cknn8DW1haWlpaYMmUK9u3bJ173F198ER4eHjA3N8d7771X6vUaPny4uP3777+PAwcOQKVSYcCAAXj8+DEePXokXp/nn39e70A8cOBAtG3bFkZGRhg2bBhu3bql135ERGXFGmwiqlVWr15dZA12TEwMXF1dxWU3Nzed92xsbGBmZiauc3V1FcsvIiIicODAAfzzzz/i+zk5OejSpYtebapXr574Ou8cGRkZSExMhLW1NczNzXXape955XI5Ro4ciSVLliAgIAASiaTI83fr1g3jxo3DZ599hoiICAwcOFDs+VYqlTrXws3NDdHR0eKyi4tLiZ8tISEBmZmZePHFF8V1giCIZSYxMTHw9vYW36tfv36JxwNQ6OukVCqRmJiIevXqYciQIdi7dy/ee+89BAcHY+XKlaUeL4/218HU1BQZGRl670tEVBYM2ERUJzg6OorBFYDOa0dHRyQnJyMzM1MMwNrvu7q6Yvjw4WKpgiHblJKSgoyMDDFkR0REiEG5tPNGR0fju+++w4svvogvvvgCO3fuLLY3d+LEiZg4cSLi4+PxwQcfYMOGDZg+fTrkcjkiIiLQvHlzAJrP7ezsLO5XMLQXXLazs4OpqSn27duns18eJycnnWsZERFR2mUp9HWSy+Wws7MDAIwcORIff/wxfHx8YGZmhg4dOpR6PCKiqsYSESKqE55//nls2bIFUVFRSE5Oxg8//CC+V79+fXh7e2PVqlVQKBS4fPmyTq/xsGHD8M8//+DEiRNQqVTIzs7G2bNnERUVVaE2FTzvhQsX9D6vIAgICAjAyy+/jKVLl8LJyQkrVqwo8jzXrl3D1atXoVQqYWZmBmNjY8hkMshkMgwZMgTffPMN0tLSEB4ejo0bN2LYsGHFttnBwQHR0dHig4BSqRSjRo3C0qVLER8fD0AT/E+cOAEAGDJkCHbt2oX79+8jMzMT3333XanXZe/eveL23377LQYPHgyZTAYA6NChA6RSKb744osS20lEVJ0YsImoVskbCSLv37Rp0wAAo0ePRs+ePTF8+HCMHDkSgwYN0tlv+fLluHLlCrp06YIVK1Zg6NChYm+wq6sr1qxZg3Xr1qFbt27o06cPfvzxR7EMoiK++uorXL16FV26dMHq1asxYsQI8b2Szvvzzz8jLi4O77//PiQSCZYuXYo///xTfPBQW3p6OubNm4fOnTujX79+sLW1xZtvvgkA+PTTT2FmZoYBAwZg7Nix8PPzw0svvVRse7t27YrmzZujZ8+eYqnKrFmz0LhxY4wePRodO3bE66+/jtDQUABAnz598Nprr+G1117DwIED0bVr11KvyfDhwxEQEIAePXpAoVBg7ty5hd6/e/cuhg8fXuqxDOHChQvsKSeiMpEIeY+yExGR6IMPPkCzZs0wY8aM6m4KFbB7925s27YNv/32W3U3hYioSOzBJiKCpowiLCwMarUax48fx5EjRzijXw2UmZmJX3/9Fa+88kp1N4WIqFh8yJGICEBcXBymT5+OpKQkuLi4YOHChWjVqlV1N4u0nDhxAtOnT0e3bt3g5+dX3c0hIioWS0SIiIiIiAyIJSJERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQHViFBG1Wo309HTI5fJC0/wSEREREQGAIAhQKpWwsLCAVFr+fug6EbDT09Nx9+7d6m4GERERET0DPDw8YGVlVe7960TAlsvlADQXK2/qYyIiIiIibQqFAnfv3hWzY3nViYCdVxZibGwMExOTam4NEREREdVkFS0p5kOOREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBmRUVScKDQ1FQEAAkpKSYGtri8DAQDRp0kRnm/j4eMyZMweRkZFQKpXo2rUr5s2bByMjI6xevRr79++HTCaDkZERZs6ciV69elVV84mIiIiI9FJlPdgLFizA2LFjcfDgQYwdOxbz588vtM3atWvh7u6OoKAgBAUF4ebNmzh06BAAoG3bttixYwf27t2LpUuXYubMmcjKyqqq5hMRERER6aVKAnZ8fDxCQkLg5+cHAPDz80NISAgSEhJ0tpNIJEhPT4darYZCoYBSqYSzszMAoFevXjAzMwMAeHp6QhAEJCUlVUXziYiIiIj0ViUBOzIyEs7OzpDJZAAAmUwGJycnREZG6mw3depUhIaGomfPnuI/Hx+fQsfbvXs3GjVqBBcXl6poPhERERGR3mrUQ44HDhyAp6cnTp48iePHj+PChQs4cOCAzjbnzp3Dt99+i6+++qqaWklEREREVLwqCdiurq6Ijo6GSqUCAKhUKsTExMDV1VVnu61bt2LYsGGQSqWwsrKCr68vzp49K75/+fJlzJo1C6tXr0azZs2qoulERERERGVSJQHbwcEBXl5eCA4OBgAEBwfDy8sL9vb2Ots1aNAAx48fBwAoFAr8999/aNGiBQDg2rVrmDlzJlauXInWrVtXRbOJiIiIiMpMIgiCUBUnevDgAQICApCSkgJra2sEBgaiWbNmmDRpEmbMmIE2bdogLCwMCxYsQFxcHFQqFbp06YK5c+fCyMgIL730EsLDw8WHHgFg2bJl8PT0LPXc2dnZuHHjRmV+PCIiIiKqJby9vWFiYlLu/assYFenvIBd0YtFRERERLWXoTJjjXrIkYiIiIjoWceATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBmRU3Q2oSjdu3KjuJhARERFRLVenAra3tzdMTEyquxlEREREVANlZ2cbpEOWJSJERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGxIBNRERERGRADNhERERERAbEgE1EREREZEAM2EREREREBsSATURERERkQAzYREREREQGVGUBOzQ0FK+88goGDx6MV155BY8ePSq0TXx8PCZPngx/f38MGTIECxcuRE5ODgBApVJh0aJFGDBgAAYOHIjt27dXVdOJiIiIiPRWZQF7wYIFGDt2LA4ePIixY8di/vz5hbZZu3Yt3N3dERQUhKCgINy8eROHDh0CAAQFBSEsLAyHDh3Ctm3bsGrVKjx9+rSqmk9EREREpJcqCdjx8fEICQmBn58fAMDPzw8hISFISEjQ2U4ikSA9PR1qtRoKhQJKpRLOzs4AgP3792PUqFGQSqWwt7fHgAEDcODAgapoPhERERGR3qokYEdGRsLZ2RkymQwAIJPJ4OTkhMjISJ3tpk6ditDQUPTs2VP85+PjIx7Dzc1N3NbV1RVRUVFV0XwiIiIiIr3VqIccDxw4AE9PT5w8eRLHjx/HhQsX2EtNRERERM+UKgnYrq6uiI6OhkqlAqB5YDEmJgaurq46223duhXDhg2DVCqFlZUVfH19cfbsWfEYERER4raRkZFwcXGpiuYTEREREemtSgK2g4MDvLy8EBwcDAAIDg6Gl5cX7O3tdbZr0KABjh8/DgBQKBT477//0KJFCwDAkCFDsH37dqjVaiQkJODw4cMYPHhwVTSfiIiIiEhvVVYisnDhQmzduhWDBw/G1q1bsWjRIgDApEmTcP36dQDAJ598gosXL8Lf3x8jRoxAkyZNMHr0aADA8OHD0aBBAwwaNAijR4/GtGnT0LBhw6pqPhERERGRXiSCIAjV3YjKlp2djRs3bsDb2xsmJibV3RwiIiIiqoEMlRlr1EOORERERETPOgZsIiIiIiIDYsAmIiIiIjIgBmwiIiIiIgNiwCYiIiIiMiCj6m5AVbpx40Z1N4GIiIiIark6FbALDrmSpVDjfEgWWjczgb21rBpbRkRERETVLW+YvoqqUwFbW45KwKyVMbj5UAFnexm2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\n",
      "text/plain": [
       "<Figure size 720x576 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num = 200\n",
    "x = range(num)\n",
    "x_low_limit = 0\n",
    "x_up_limit = 200\n",
    "sep = 4\n",
    "\n",
    "y_low_limit = 0.68\n",
    "y_up_limit = 0.83\n",
    "y_low_limit_2, y_up_limit_2 = 0, 2\n",
    "fig, ax = plt.subplots(2, 1, figsize=(10, 8), gridspec_kw={'height_ratios': [1, 3]}, constrained_layout=True)\n",
    "infl_edges = pubmed_infl.loc[0:num-1]['predicted_influence'].values\n",
    "ax[0].set_ylabel('Infl.')\n",
    "ax[0].bar(x, infl_edges, label = 'test accuracy', color = '#446CCF')\n",
    "ax[0].set_ylim(y_low_limit_2, y_up_limit_2)\n",
    "ax[0].set_xlabel('Edge Index sorted by Infl.', loc=\"center\", size = 12)\n",
    "ax[0].set_xlim(x_low_limit-0.5, x_up_limit)\n",
    "grid_x_ticks = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks = np.arange(y_low_limit_2, y_up_limit_2, (y_up_limit_2 - y_low_limit_2) / sep)\n",
    "\n",
    "ax[0].set_xticks(grid_x_ticks , minor=True)\n",
    "ax[0].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "ax[0].grid(which='both')\n",
    "\n",
    "ax[0].grid(which='minor', alpha=1, linestyle='-')\n",
    "\n",
    "\n",
    "\n",
    "ax[1].plot(x, acc_pubmed[0:num], linestyle='solid', color='firebrick', linewidth=3, label = 'test accuracy')\n",
    "ax[1].plot(x, acc2_pubmed[0:num], linestyle='solid', color='royalblue', linewidth=3, label = 'val accuracy')\n",
    "ax[1].axhline(y=0.78, color='green', linestyle='--',linewidth=3, label = 'SGC')\n",
    "ax[1].set_xlim(x_low_limit, x_up_limit)\n",
    "ax[1].set_ylim(y_low_limit, y_up_limit)\n",
    "# fig.supxlabel('Number edges')\n",
    "ax[1].set_ylabel('Acc.')\n",
    "\n",
    "ax[1].set_xlabel('Num. Influential Edges removed', loc=\"center\", size = 12)\n",
    "\n",
    "\n",
    "grid_x_ticks_2 = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks_2 = np.arange(y_low_limit, y_up_limit, (y_up_limit - y_low_limit) / 13)\n",
    "\n",
    "ax[1].set_xticks(grid_x_ticks_2 , minor=True)\n",
    "ax[1].set_yticks(grid_y_ticks_2 , minor=True)\n",
    "\n",
    "ax[1].grid(which='both')\n",
    "\n",
    "ax[1].grid(which='minor', alpha=1, linestyle='-')\n",
    "ax[1].legend(loc = (0.05, 0.05), prop={'size': 18})\n",
    "\n",
    "\n",
    "fig.suptitle('pubmed: removing high influential edges', x = 0.55)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "1fe26656",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.78,\n",
       " 0.779,\n",
       " 0.78,\n",
       " 0.77,\n",
       " 0.771,\n",
       " 0.766,\n",
       " 0.768,\n",
       " 0.765,\n",
       " 0.769,\n",
       " 0.765,\n",
       " 0.761,\n",
       " 0.755,\n",
       " 0.755,\n",
       " 0.754,\n",
       " 0.743,\n",
       " 0.744,\n",
       " 0.754,\n",
       " 0.75,\n",
       " 0.756,\n",
       " 0.757,\n",
       " 0.758,\n",
       " 0.758,\n",
       " 0.766,\n",
       " 0.769,\n",
       " 0.769,\n",
       " 0.768,\n",
       " 0.766,\n",
       " 0.765,\n",
       " 0.764,\n",
       " 0.763,\n",
       " 0.764,\n",
       " 0.763,\n",
       " 0.764,\n",
       " 0.762,\n",
       " 0.756,\n",
       " 0.755,\n",
       " 0.757,\n",
       " 0.754,\n",
       " 0.752,\n",
       " 0.749,\n",
       " 0.753,\n",
       " 0.752,\n",
       " 0.757,\n",
       " 0.757,\n",
       " 0.739,\n",
       " 0.732,\n",
       " 0.73,\n",
       " 0.73,\n",
       " 0.731,\n",
       " 0.732,\n",
       " 0.733,\n",
       " 0.733,\n",
       " 0.733,\n",
       " 0.734,\n",
       " 0.735,\n",
       " 0.733,\n",
       " 0.736,\n",
       " 0.736,\n",
       " 0.735,\n",
       " 0.736,\n",
       " 0.737,\n",
       " 0.732,\n",
       " 0.732,\n",
       " 0.73,\n",
       " 0.731,\n",
       " 0.729,\n",
       " 0.728,\n",
       " 0.729,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.726,\n",
       " 0.727,\n",
       " 0.729,\n",
       " 0.729,\n",
       " 0.729,\n",
       " 0.729,\n",
       " 0.729,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.728,\n",
       " 0.727,\n",
       " 0.725,\n",
       " 0.725,\n",
       " 0.724,\n",
       " 0.724,\n",
       " 0.724,\n",
       " 0.724,\n",
       " 0.724,\n",
       " 0.725,\n",
       " 0.726,\n",
       " 0.724,\n",
       " 0.712,\n",
       " 0.712,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.709,\n",
       " 0.711,\n",
       " 0.711,\n",
       " 0.711,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.707,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.711,\n",
       " 0.711,\n",
       " 0.711,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.708,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.71,\n",
       " 0.71,\n",
       " 0.709,\n",
       " 0.709,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.708,\n",
       " 0.706,\n",
       " 0.706,\n",
       " 0.706,\n",
       " 0.706,\n",
       " 0.706,\n",
       " 0.702,\n",
       " 0.702,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.7,\n",
       " 0.7,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.7,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.701,\n",
       " 0.699,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.697,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.699,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.698,\n",
       " 0.697,\n",
       " 0.694,\n",
       " 0.694,\n",
       " 0.694,\n",
       " 0.694,\n",
       " 0.693,\n",
       " 0.693,\n",
       " 0.693,\n",
       " 0.693,\n",
       " 0.693,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.692,\n",
       " 0.69,\n",
       " 0.69,\n",
       " 0.689,\n",
       " 0.691,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.693,\n",
       " 0.693,\n",
       " 0.691,\n",
       " 0.69,\n",
       " 0.69,\n",
       " 0.69,\n",
       " 0.689,\n",
       " 0.689,\n",
       " 0.691,\n",
       " 0.691,\n",
       " 0.691,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.688,\n",
       " 0.686,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.686,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.687,\n",
       " 0.686,\n",
       " 0.686,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.684,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.685,\n",
       " 0.684,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.682,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.683,\n",
       " 0.682,\n",
       " 0.682,\n",
       " 0.682,\n",
       " 0.68,\n",
       " 0.68,\n",
       " 0.68,\n",
       " 0.68,\n",
       " 0.68,\n",
       " 0.68,\n",
       " 0.679,\n",
       " 0.678,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.676,\n",
       " 0.677,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.678,\n",
       " 0.678,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.677,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.676,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.673,\n",
       " 0.674,\n",
       " 0.673,\n",
       " 0.673,\n",
       " 0.672,\n",
       " 0.672,\n",
       " 0.672,\n",
       " 0.672,\n",
       " 0.672,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.673,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.675,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.674,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.67,\n",
       " 0.671,\n",
       " 0.671,\n",
       " 0.67,\n",
       " 0.67,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.67,\n",
       " 0.67,\n",
       " 0.67,\n",
       " 0.671,\n",
       " 0.668,\n",
       " 0.668,\n",
       " 0.668,\n",
       " 0.668,\n",
       " 0.667,\n",
       " 0.667,\n",
       " 0.667,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.67,\n",
       " 0.67,\n",
       " 0.67,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.669,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.662,\n",
       " 0.661,\n",
       " 0.661,\n",
       " 0.661,\n",
       " 0.661,\n",
       " 0.661,\n",
       " 0.663,\n",
       " 0.663,\n",
       " 0.663]"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "bfdcf25e",
   "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"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████| 2139/2139 [06:21<00:00,  5.61it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "data_set_2 = 'citeseer'\n",
    "l2_term = 0.003\n",
    "num_layer = 2\n",
    "\n",
    "loader_citeseer = train_preprocessed_data(data_name = data_set_2, 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_2)\n",
    "\n",
    "citeseer_infl = pd.read_csv('result_data/citeseer_edge_influence_new_version.csv')\n",
    "citeseer_infl = citeseer_infl.loc[citeseer_infl['predicted_influence'] > 0]\n",
    "citeseer_infl = citeseer_infl.sort_values(['predicted_influence'], ascending=False)\n",
    "citeseer_infl.index = range(len(citeseer_infl))\n",
    "\n",
    "n = citeseer_infl.shape[0]\n",
    "i = 2\n",
    "\n",
    "acc_citeseer = []\n",
    "acc2_citeseer = []\n",
    "\n",
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_citeseer = citeseer_infl.loc[0:i]['from_edges'].values.astype(int)\n",
    "    to_index_citeseer = citeseer_infl.loc[0:i]['to_edges'].values.astype(int)\n",
    "\n",
    "\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_citeseer = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, 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": 21,
   "id": "c1ba856b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df3 = pd.DataFrame([acc2_citeseer, acc_citeseer]).T\n",
    "df3.columns = ['validate acc', 'test acc']\n",
    "df3.to_csv('drop_acc/citeseer_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "2e6fd13c",
   "metadata": {},
   "outputs": [],
   "source": [
    "citeseer_infl.to_csv('drop_acc/citeseer_edge_influence_positive_no_self_loop.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "15e89eb8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.55, 0.98, 'citeseer: removing high influential edges')"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAtgAAAJICAYAAABbtZNGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAADQ7ElEQVR4nOzdd1zU9R8H8NfdwbGHTEFUFENJ3LhXbisQ1Bw509JM07ZalmlZhlk50kwa/hyZqSmCpqaZinsv3IGoLFmyObj7/v44+XLH8oCDY7yejweP7vu973jf+YXe97n39/2RCIIggIiIiIiI9EJq6ACIiIiIiGoTJthERERERHrEBJuIiIiISI+YYBMRERER6RETbCIiIiIiPWKCTURERESkR0ywiUjL+PHjMW/ePEOHQSU4deoUmjdvjtjY2Eo/159//olnn3221G0ePHiA5s2b4+zZs2U6dvPmzREcHFymfcp7rvT0dMyYMQPt27dH8+bN8eDBg2p5nfft2xerV68u0z7leR91UZXXGVFtZGToAIioelm5ciWMjAr+NLzyyiuoX78+vvrqKwNGRfnatWuHsLAw2NvbGzoUAICLiwvCwsJga2tbbc/122+/4eLFi9i8eTPs7OxgZ2dXOQHqaN68eYiKisKGDRu01m/btg2mpqYGioqI9IkJNhFpqYpEqTIpFArI5fIq37eqyOVyODo6GjoMkUwmq7J4ynuue/fuoVmzZmjevHklRKU/hk78iUh/WCJCVAdt2rQJL7zwAry9vdG1a1fMmjVLfE7zq/O5c+fixIkT2LFjB5o3b47mzZvj1KlTAICEhATMnTsXXbp0Qbt27TB69GicOXNGPE5ubi4WL16MXr16wdvbGz169MA777yjFcfu3bvh7++PVq1aoW/fvli8eDEyMzO1ttmwYQMGDx6MVq1aYeDAgfjhhx+Ql5cnPt+3b1989913WLBgATp37oyXX35Z5/ehpH2vXr2KyZMno127dujSpQvefPNNPHz4UNxv5cqVGDBgAPbs2YOBAweiTZs2mD59OtLT07F//34MGjQI7dq1w6xZs5CWlibuJwgCfv75Z/Tr1w/e3t7o378/1q1bJz7/3XffYdCgQUXi/PTTTzFy5EgARb+6z18+duwYxo4dizZt2uCFF17A0aNHtY4RHh6OkSNHolWrVhg0aBD27t2rc0nCuXPnMHToULRp0wbDhw/H1atXxeeKK9vQ9Vzp6en44IMP0K5dO/Tu3RtBQUGlxlH4XPnLe/bswbRp09CmTRv069cPO3fuFPfp27cvtm3bhpMnT6J58+YYP358sccurmRk9erV6Nu3r9a6p12z+cdZtWoVunfvjk6dOmHu3LniNitXrsS2bdtw+vRp8Xfqzz//FGPVfI9CQkIwYsQIdOjQAZ07d8bUqVMRERFR6ntUnKddz4D696xXr15o06YNXn31VcTExBQ5TmhoKPr3749WrVph9OjROHToUJF/+3v37mHmzJnw8fFBx44dMXnyZNy8eVN8Pj09HR9++CG6d+8Ob29v9O7dG4sXLy7zayKq7phgE9UxK1aswNKlSzFmzBiEhITgp59+QosWLYrddt68efDx8cHzzz+PsLAwhIWFoV27dsjOzsaECROQkZGBoKAg7Ny5E71798akSZNw9+5dAMDGjRvx119/4euvv8b+/fuxevVqtGnTRjz2n3/+iQULFmDSpEnYs2cPAgMDcfz4cXz66afiNitXrsQvv/yC9957D3v27MG8efOwZcsWfP/991pxbtiwAfb29vj9998RGBgIQJ2szJ0796nvR+F979y5g/Hjx6Nt27bYtm0b/ve//0EqlWLy5MnIyckR93v06BF27tyJFStWICgoCOfPn8esWbOwdetWLF++HEFBQTh79izWrFkj7vPbb79h+fLlmDp1KkJDQ/Hqq6/im2++wdatWwEAAQEBiIyMxIULF8R9FAoF9u7di4CAgFJfR2BgIF5//XUEBwfD29sb77zzDlJTUwEAWVlZmDp1Kuzs7LB161YEBgZi3bp1SExMfOr7o1Kp8O2332LevHn4888/YWNjg7ffflvrQ46mspxr1apV6NixI4KDg/Hqq69i6dKlOHny5FNjKuybb77BkCFDsGvXLjz//PP46KOPEBkZCUBddvH888/Dx8cHYWFhWLlyZZmPn0+XaxYA9u3bh8ePH2P9+vVYunQpDhw4gJ9++gkAMHnyZPj6+oqlPmFhYXjhhReKPZ9CocD06dOxY8cO/Prrr5BKpXj99dehUCh0jlmX6/nAgQNYvHgxJk2ahJ07d2Lw4MFYsmSJ1nGuXr2K999/Hy+++CKCg4Px2muv4csvv9TaJiEhAWPGjIGdnR02bdqELVu2oEmTJpgwYQKSkpIAAMuWLcO1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DxYtWkSXLl3o1q0bq1atAuB///sf69evZ+HChTajy7179+aPP/4AYN++fYwYMYKOHTvSrVs3pk+fTn5+foXOwY2+/PJLunXrRrdu3Vi5cqXNsrS0NJ5//nnat2/P0KFD+fTTT23OQUJCAk8++SRhYWH07duXjRs3WpfFxsbSv39/QkND6d69OwsXLix2/4V/32FhYcyaNcuuc/nFF19Yz+Wvv/5KbGwsffv2JSwsjPnz51vbz8/P57333rMe43vvvWc9dw8++CBbtmyxrms0GuncuTMHDx4EYM+ePTz88MN07NiRQYMG2aTsnD17lkcffZTQ0FCefPJJ0tLSKvorEELcAiTAFkJUuzZt2hAWFlZiUFWWffv2ERwcTHx8PBEREbz88svs37+fX375hY8++ojp06eTlZVVobY3b97MgAED2LlzJ7179+add94BYMmSJXTs2JG33nqL3bt306RJk3K1+9FHH3Hy5EnWrl3Lzz//THJyMnPmzLEuv3TpEhkZGcTFxfHee+8xffp00tPTGTFiBAMHDuSpp55i9+7dNsHhdWq1mldffZXt27fz7bff8ueff7J8+fIKHX9hcXFxLFq0iEWLFvHzzz/z559/2iyfPn06Li4u/P7778ycOZO1a9dal2VnZzNmzBgiIiL4448/+O9//8u0adM4duwYAK+//jrTp09n9+7dxMTEcM8995TYj3379tGoUSP++OMPxo4da9e5zMvLIy4ujgkTJvDGG2+wbt06Vq1axbJly6xTnAPMmzePvXv3Eh0dzbp169i/fz9z584FLHnuMTEx1na3bduGt7c3rVu3Jikpieeee46xY8fy119/MXnyZCZMmMDly5cBmDhxIq1btyY+Pp5x48ZV+EOfEOLWIAG2EKJGmDBhAt988401ICmPwMBAhg4dikajoX///ly4cIHx48ej1+vp1q0ber2eM2fOVKhfHTp0IDw8HI1GQ2RkJEeOHKlQO4UpisL333/Pa6+9hpeXF+7u7jz33HNs2LDBuo5Wq2X8+PHodDrCw8NxdXUtMkpekjZt2tCuXTu0Wi2BgYGMGDGCHTt22N2/d999l44dO1p/PvvsMwB++OEHhgwZQsuWLXF1deVf//qXdRuTycTPP//MCy+8gIuLC82bNycqKsq6fOvWrTRs2JChQ4ei1Wpp3bo1ffv25aeffrIe7/Hjx8nMzKROnTq0bt26xP75+fkxevRotFotTk5Odp3LsWPHotPp6N+/P2lpaTz22GO4u7vTokULWrRowdGjRwFYv34948ePx8fHh7p16zJ+/HjWrVsHwMCBA9m8eTM5OTnWdSMiIgCIjo6mR48ehIeHo1ar6dq1K23atCE2Npbz58+zf/9+XnzxRfR6PZ06daJ37952/z6EELceSVwTQtQILVu2pGfPnnz++ec0a9asXNv6+PhYHzs7OwNQr14962tOTk4VHsEu3I6zszN5eXk3nfd7+fJlcnJyGDJkiPU1RVEwm83W515eXjb7cHFxsbkRtDQnT57kgw8+4MCBA+Tk5GAymUoNWG/0xhtvFJuDnZycTJs2bazPGzZsaHNMRqORgIAA62uFH587d459+/bRsWNH62smk4lBgwYB8H//93/MmzePTz75hODgYF555RVCQ0OL7V/9+vVt9mvPudRoNEDB9VH4mil8fSQnJ9OgQQPrsgYNGpCcnAxAUFAQzZo1Y8uWLfTq1YvNmzdbR+nPnz/Pjz/+WGwKSXJyMp6enri6utq0e+HChWKPTwhx65MAWwhRY0yYMIHBgwczZswY62vXg5Lc3Fzc3d0BSElJqZb+lYeLi4s1Dxhs++zt7Y2zszMbNmzA39+/3G2rVKpSl0+dOpU777yTTz75BHd3d7766ivrSPHN8PPzswkKz58/b31ct25dtFotFy9etKbLFF43ICCATp06sXjx4mLbbtu2LfPmzcNgMLBs2TJeeuklYmNji1238PHf7Lm8kZ+fH+fPn6dFixbWY/Dz87Muj4iIICYmBrPZTPPmzQkKCrIeX2RkJO+++26RNs+dO8fVq1fJzs62Xs/nz58v8/cohLh1SYqIEKLGCAoKon///ixdutT6Wt26dfH39yc6OhqTycTKlSut+bI1WatWrTh27BiHDx8mLy+PWbNmWZep1WqGDx/OjBkzSE1NBSApKYnffvvNrrZ9fHxITEwscXlWVhZubm64ubmRkJDAihUrbu5grunXrx9r1qzh+PHj5OTkMHv2bOsyjUbD/fffz+zZs8nJySEhIYHo6Gjr8p49e3Lq1CnWrl2LwWDAYDCwb98+EhISyM/PZ926dWRkZKDT6XBzc7OOOJflZs/ljQYMGMC8efO4fPkyly9fZs6cOQwcONC6vH///vz++++sWLHCmh4CMGjQILZs2cJvv/2GyWQiLy+P+Ph4Ll68SMOGDWnTpo31hsydO3fajHQLIWofCbCFEDXK+PHji6RCvPPOOyxcuJDOnTtz/PjxElMH7DF//nyefvrpm+1mmZo0acL48eN54okneOCBB+jQoYPN8v/85z8EBQXx0EMP0b59e5544gm7c6yHDRvG8ePH6dixI+PGjSuyfPLkycTExNC+fXvefPNN+vfvX66+X6+Mcv3nevpFeHg4jz/+OI8//jj3339/kRsR33rrLTIyMujatSuTJk1iwIAB6PV6ANzd3Vm4cCEbN26ke/fudOvWjY8//thaoSM6OprevXvTvn17vv32Wz788EO7+3sz5/JG48aNo02bNgwaNIhBgwbRunVrm3Ps5+dHu3bt2L17t815DQgIYO7cuSxYsIAuXboQHh7OwoULrakqn3zyCXv37qVz587MmTPHJj9dCFH7qBRFUaq7E0IIIWqfjz76iEuXLjFz5szq7ooQQlQpGcEWQgjhEAkJCRw5cgRFUdi3bx8rV67k/vvvr+5uCSFElZObHIUQQjhEVlYWr7zyCsnJyfj4+DBmzBj69OlT3d0SQogqJykiQgghhBBCOJCkiAghhBBCCOFAEmALIYQQQgjhQBJgCyGEEEII4UASYAshhBBCCOFAEmALIYQQQgjhQBJgCyGEEEII4UD/HwmVCMpjp4+nAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 720x576 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "num = 200\n",
    "x = range(num)\n",
    "x_low_limit = 0\n",
    "x_up_limit = 200\n",
    "sep = 4\n",
    "\n",
    "y_low_limit = 0.65\n",
    "y_up_limit = 0.74\n",
    "y_low_limit_2, y_up_limit_2 = 0, 2\n",
    "fig, ax = plt.subplots(2, 1, figsize=(10, 8), gridspec_kw={'height_ratios': [1, 3]}, constrained_layout=True)\n",
    "infl_edges = citeseer_infl.loc[0:num-1]['predicted_influence'].values\n",
    "ax[0].set_ylabel('Infl.')\n",
    "ax[0].bar(x, infl_edges, label = 'test accuracy', color = '#446CCF')\n",
    "ax[0].set_ylim(y_low_limit_2, y_up_limit_2)\n",
    "ax[0].set_xlabel('Edge Index sorted by Infl.', loc=\"center\", size = 12)\n",
    "ax[0].set_xlim(x_low_limit-0.5, x_up_limit)\n",
    "grid_x_ticks = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks = np.arange(y_low_limit_2, y_up_limit_2, (y_up_limit_2 - y_low_limit_2) / sep)\n",
    "\n",
    "ax[0].set_xticks(grid_x_ticks , minor=True)\n",
    "ax[0].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "ax[0].grid(which='both')\n",
    "\n",
    "ax[0].grid(which='minor', alpha=1, linestyle='-')\n",
    "\n",
    "\n",
    "\n",
    "ax[1].plot(x, acc_citeseer[0:num], linestyle='solid', color='firebrick', linewidth=3, label = 'test accuracy')\n",
    "ax[1].plot(x, acc2_citeseer[0:num], linestyle='solid', color='royalblue', linewidth=3, label = 'val accuracy')\n",
    "ax[1].axhline(y=0.723, color='green', linestyle='--',linewidth=3, label = 'SGC')\n",
    "ax[1].set_xlim(x_low_limit, x_up_limit)\n",
    "ax[1].set_ylim(y_low_limit, y_up_limit)\n",
    "# fig.supxlabel('Number edges')\n",
    "ax[1].set_ylabel('Acc.')\n",
    "\n",
    "ax[1].set_xlabel('Num. Influential Edges removed', loc=\"center\", size = 12)\n",
    "\n",
    "\n",
    "grid_x_ticks_2 = np.arange(x_low_limit, x_up_limit, (x_up_limit - x_low_limit) / sep)\n",
    "grid_y_ticks_2 = np.arange(y_low_limit, y_up_limit, (y_up_limit - y_low_limit) / 13)\n",
    "\n",
    "ax[1].set_xticks(grid_x_ticks_2 , minor=True)\n",
    "ax[1].set_yticks(grid_y_ticks_2 , minor=True)\n",
    "\n",
    "ax[1].grid(which='both')\n",
    "\n",
    "ax[1].grid(which='minor', alpha=1, linestyle='-')\n",
    "ax[1].legend(loc = (0.05, 0.05))\n",
    "\n",
    "\n",
    "fig.suptitle('citeseer: removing high influential edges', x = 0.55)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "afa18934",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.778\n",
      "0.0\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": 20,
   "id": "f08e3735",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_47927/811900443.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'number of edges to be removed'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolumns\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m'test accuracy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'val_accuracy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'SGC'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'Best accuracy reported in paper'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'number of edges to be removed'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto_csv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'visulize/attack_on_accuracy/cora.csv'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/core/generic.py\u001b[0m in \u001b[0;36mto_csv\u001b[0;34m(self, path_or_buf, sep, na_rep, float_format, columns, header, index, index_label, mode, encoding, compression, quoting, quotechar, line_terminator, chunksize, date_format, doublequote, escapechar, decimal, errors, storage_options)\u001b[0m\n\u001b[1;32m   3464\u001b[0m         )\n\u001b[1;32m   3465\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3466\u001b[0;31m         return DataFrameRenderer(formatter).to_csv(\n\u001b[0m\u001b[1;32m   3467\u001b[0m             \u001b[0mpath_or_buf\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3468\u001b[0m             \u001b[0mline_terminator\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mline_terminator\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/formats/format.py\u001b[0m in \u001b[0;36mto_csv\u001b[0;34m(self, path_or_buf, encoding, sep, columns, index_label, mode, compression, quoting, quotechar, line_terminator, chunksize, date_format, doublequote, escapechar, errors, storage_options)\u001b[0m\n\u001b[1;32m   1103\u001b[0m             \u001b[0mformatter\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfmt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1104\u001b[0m         )\n\u001b[0;32m-> 1105\u001b[0;31m         \u001b[0mcsv_formatter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msave\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1106\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1107\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mcreated_buffer\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/formats/csvs.py\u001b[0m in \u001b[0;36msave\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    235\u001b[0m         \"\"\"\n\u001b[1;32m    236\u001b[0m         \u001b[0;31m# apply compression and byte/text conversion\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 237\u001b[0;31m         with get_handle(\n\u001b[0m\u001b[1;32m    238\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    239\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/common.py\u001b[0m in \u001b[0;36mget_handle\u001b[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[0m\n\u001b[1;32m    700\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mencoding\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m\"b\"\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    701\u001b[0m             \u001b[0;31m# Encoding\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 702\u001b[0;31m             handle = open(\n\u001b[0m\u001b[1;32m    703\u001b[0m                 \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    704\u001b[0m                 \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'"
     ]
    }
   ],
   "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": 21,
   "id": "96bb4062",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_47927/4235208590.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mpd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mread_csv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'visulize/attack_on_accuracy/cora.csv'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/util/_decorators.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    309\u001b[0m                     \u001b[0mstacklevel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstacklevel\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    310\u001b[0m                 )\n\u001b[0;32m--> 311\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    312\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    313\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36mread_csv\u001b[0;34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, squeeze, prefix, mangle_dupe_cols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, error_bad_lines, warn_bad_lines, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options)\u001b[0m\n\u001b[1;32m    584\u001b[0m     \u001b[0mkwds\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkwds_defaults\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    585\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 586\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0m_read\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    587\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    588\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m_read\u001b[0;34m(filepath_or_buffer, kwds)\u001b[0m\n\u001b[1;32m    480\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    481\u001b[0m     \u001b[0;31m# Create the parser.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 482\u001b[0;31m     \u001b[0mparser\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mTextFileReader\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    483\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    484\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mchunksize\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0miterator\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, f, engine, **kwds)\u001b[0m\n\u001b[1;32m    809\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"has_index_names\"\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"has_index_names\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    810\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 811\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_engine\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_make_engine\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mengine\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    812\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    813\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mclose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m_make_engine\u001b[0;34m(self, engine)\u001b[0m\n\u001b[1;32m   1038\u001b[0m             )\n\u001b[1;32m   1039\u001b[0m         \u001b[0;31m# error: Too many arguments for \"ParserBase\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1040\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mmapping\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mengine\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[call-arg]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1041\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1042\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_failover_to_python\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/c_parser_wrapper.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, src, **kwds)\u001b[0m\n\u001b[1;32m     49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     50\u001b[0m         \u001b[0;31m# open handles\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 51\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_open_handles\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msrc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     52\u001b[0m         \u001b[0;32massert\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhandles\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     53\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/base_parser.py\u001b[0m in \u001b[0;36m_open_handles\u001b[0;34m(self, src, kwds)\u001b[0m\n\u001b[1;32m    220\u001b[0m         \u001b[0mLet\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mreaders\u001b[0m \u001b[0mopen\u001b[0m \u001b[0mIOHandles\u001b[0m \u001b[0mafter\u001b[0m \u001b[0mthey\u001b[0m \u001b[0mare\u001b[0m \u001b[0mdone\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mtheir\u001b[0m \u001b[0mpotential\u001b[0m \u001b[0mraises\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    221\u001b[0m         \"\"\"\n\u001b[0;32m--> 222\u001b[0;31m         self.handles = get_handle(\n\u001b[0m\u001b[1;32m    223\u001b[0m             \u001b[0msrc\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    224\u001b[0m             \u001b[0;34m\"r\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/common.py\u001b[0m in \u001b[0;36mget_handle\u001b[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[0m\n\u001b[1;32m    700\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mencoding\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m\"b\"\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    701\u001b[0m             \u001b[0;31m# Encoding\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 702\u001b[0;31m             handle = open(\n\u001b[0m\u001b[1;32m    703\u001b[0m                 \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    704\u001b[0m                 \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'"
     ]
    }
   ],
   "source": [
    "pd.read_csv('visulize/attack_on_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "0dcac9c7",
   "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_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": "d30ed925",
   "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": "182c855e",
   "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": "f30a0b8e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAY4AAAEWCAYAAABxMXBSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABJ1UlEQVR4nO3dd3hVxdbA4d9KgRBK6CUUQarUIE3EAoIUpYhSrdgoildsVyxXsV4+u14VBAUUUUQUUUSKSFMRKUaq9Cgh9B4Cqev7Y++Ek+Qk5JAcEsh6nydPzt57Zp+ZEM7KlD0jqooxxhiTUwH5XQBjjDHnFwscxhhjfGKBwxhjjE8scBhjjPGJBQ5jjDE+scBhjDHGJxY4jDlLInKLiMzL73IYc66JPcdhTN4QEQXqqurW/C6LMf5kLQ5jLlDisP/jJs/ZL5UxOSAi1UXkaxHZLyIHReRdERkkIj+715e4Sf8UkVgR6e+e7y4ikSJyRER+FZGmHvd8XER2ichxEdkkIh3d8wEiMlJEtrnvNU1Eynrku8y91xER+VNE2ntcWyQiL4nIL0AccLHffzim0LHAYcwZiEggMAv4G6gJVAWmeqZR1avcl81UtYSqfiEilwITgCFAOeAD4FsRKSoi9YHhQCtVLQl0AaLce/wLuAG4GggHDgPvuWWpCnwPvAiUBR4FvhKRCh7FuQ0YDJR0y2xMnrLAYcyZtcb5AH9MVU+o6ilV/TkH+e4FPlDV5aqarKofA/HAZUAyUBRoKCLBqhqlqtvcfEOAp1Q1WlXjgVFAHxEJAm4FZqvqbFVNUdX5wErgOo/3naSq61U1SVUT86D+xqRjgcOYM6sO/K2qST7muwh4xO1SOiIiR9x7hbsD6CNwgsI+EZkqIuEe+WZ45NmIE2gqudf6ZrjnFUAVj/fdeRZ1NCbHLHAYc2Y7gRruX/y+5ntJVUt7fIWq6ucAqvqZql6BEwwU+D+PfN0y5AtR1V3utckZrhVX1dEe72tTJY1fWeAw5sx+B3YDo0WkuIiEiEg7L+n2kn4wejwwVETauDOciovI9SJSUkTqi8g1IlIUOAWcxGlVAIwFXhKRiwBEpIKI9HKvfQr0EJEuIhLolqW9iFTzQ72N8coChzFnoKrJQA+gDvAPEA3095J0FPCx24XUT1VX4oxzvIszwL0VGOSmLQqMBg4Ae4CKwJPutbeBb4F5InIc+A1o45ZlJ9DLTbsfpwXyGPZ/2ZxD9gCgMcYYn9hfKcYYY3zi18AhIl3dB5u2ishIL9fDROQ79yGm9SJy55nyikhZEZkvIlvc72X8WQdjjDHp+S1wuA9NvQd0AxoCA0WkYYZk9wMbVLUZ0B54XUSKnCHvSGCBqtYFFrjHxhhjzhF/tjhaA1tVdbuqJuA8adsrQxoFSoqIACWAQ0DSGfL2Aj52X3+M84StMcaYc8TXeem+qEr6B5GicWeGeHgXZ/ZIDM7yCP1VNcVdViGrvJVUdTeAqu4WkYre3lxEBuMsu0Dx4sVbNGjQIJfVMcaYwmXVqlUHVLVCxvP+DBzi5VzGKVxdgEjgGqA2MF9EluYwb7ZUdRwwDqBly5a6cuVKX7IbY0yhJyJe1zrzZ1dVNM7yCqmq4bQsPN0JfK2OrcAOoMEZ8u4VkSoA7vd9fii7McaYLPgzcKwA6opILREpAgzA6Zby9A+QupR0JaA+sP0Meb8F7nBf3wHM9GMdjDHGZOC3ripVTRKR4cBcIBCYoKrrRWSoe30s8AIwSUTW4nRPPa6qBwC85XVvPRqYJiJ34wSevv6qgzHGmMwKxZPj3sY4EhMTiY6O5tSpU/lUKuNNSEgI1apVIzg4OL+LYkyhJyKrVLVlxvP+HBwv0KKjoylZsiQ1a9bEmQ1s8puqcvDgQaKjo6lVq1Z+F8cYk4VCu+TIqVOnKFeunAWNAkREKFeunLUCjSngCm3gACxoFED2b2JMwVeoA4cxxhjfWeDIJ0eOHOH9998/6/xvvfUWcXFxeVgiY4zJGQsc+eRCCBxJSb5uwW2MuRBY4MgnI0eOZNu2bURERPDYY48B8Oqrr9KqVSuaNm3Ks88+C8CJEye4/vrradasGY0bN+aLL77gnXfeISYmhg4dOtChQ4dM937++edp1aoVjRs3ZvDgwaROud66dSudOnWiWbNmXHrppWzbtg2AV155hSZNmtCsWTNGjnQWG27fvj2pU5gPHDhAzZo1AZg0aRJ9+/alR48edO7cmdjYWDp27Mill15KkyZNmDnz9POYn3zyCU2bNqVZs2bcdtttHD9+nFq1apGYmAjAsWPHqFmzZtqxMeb8UGin43p67rv1bIg5lqf3bBheimd7NMry+ujRo1m3bh2RkZEAzJs3jy1btvD777+jqvTs2ZMlS5awf/9+wsPD+f777wE4evQoYWFhvPHGGyxcuJDy5ctnuvfw4cN55plnALjtttuYNWsWPXr04JZbbmHkyJH07t2bU6dOkZKSwg8//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": "44a67ad5",
   "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": "bd7c8c33",
   "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": "5683f798",
   "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": "1d71b84e",
   "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": "9d9cd345",
   "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": "d3b5ead5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.758"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "84545b52",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "016f0552",
   "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": "2be99740",
   "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": "a8265ecb",
   "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": "ba80773b",
   "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": "acf66441",
   "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": "02515fd2",
   "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": "002e8bf9",
   "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": "2dca2cd1",
   "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
}
