{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a94206c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "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": 2,
   "id": "98412d2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.01\n",
    "# l2_term_1 = 0.01\n",
    "data_set_2 = 'pubmed'\n",
    "l2_term_2 = 0.004\n",
    "\n",
    "data_set_3 = 'citeseer'\n",
    "l2_term_3 = 0.003\n",
    "\n",
    "num_layer = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c4030296",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_cora = train_preprocessed_data(data_name = data_set_1, k = num_layer)\n",
    "train_x_cora, train_y_cora, test_x_cora, test_y_cora, val_x_cora, val_y_cora = loader_cora.load_graph_to_tabular()\n",
    "graph_cora, feat_cora, labels_cora, train_mask_cora, val_mask_cora, test_mask_cora, number_classes_cora = load_graph_dataset(data_set_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "adb0598b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_pubmed = train_preprocessed_data(data_name = data_set_2, k = num_layer)\n",
    "train_x_pubmed, train_y_pubmed, test_x_pubmed, test_y_pubmed, val_x_pubmed, val_y_pubmed = loader_pubmed.load_graph_to_tabular()\n",
    "graph_pubmed, feat_pubmed, labels_pubmed, train_mask_pubmed, val_mask_pubmed, test_mask_pubmed, number_classes_pubmed = load_graph_dataset(data_set_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "44f9ebf5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_citeseer = train_preprocessed_data(data_name = data_set_3, k = num_layer)\n",
    "train_x_citeseer, train_y_citeseer, test_x_citeseer, test_y_citeseer, val_x_citeseer, val_y_citeseer = loader_citeseer.load_graph_to_tabular()\n",
    "graph_citeseer, feat_citeseer, labels_citeseer, train_mask_citeseer, val_mask_citeseer, test_mask_citeseer, number_classes_citeseer = load_graph_dataset(data_set_3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d330dfa2",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl = pd.read_csv('result_data/cora_edge_influence_001.csv', header = None)\n",
    "cora_infl = cora_infl.loc[cora_infl[0] < 0]\n",
    "cora_infl = cora_infl.sort_values([1])\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "316c0103",
   "metadata": {},
   "outputs": [],
   "source": [
    "pubmed_infl = pd.read_csv('result_data/pubmed_edge_influence_001.csv', header = None)\n",
    "pubmed_infl = pubmed_infl.loc[pubmed_infl[0] < 0]\n",
    "pubmed_infl = pubmed_infl.sort_values([1])\n",
    "pubmed_infl.index = range(len(pubmed_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "69f7bdcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pubmed_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c487ff80",
   "metadata": {},
   "outputs": [],
   "source": [
    "citeseer_infl = pd.read_csv('result_data/citeseer_edge_influence_001.csv', header = None)\n",
    "citeseer_infl = citeseer_infl.loc[citeseer_infl[0] < 0]\n",
    "citeseer_infl = citeseer_infl.sort_values([1])\n",
    "citeseer_infl.index = range(len(citeseer_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f7dd218d",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "i = 2\n",
    "\n",
    "acc_cora = []\n",
    "acc2_cora = []\n",
    "\n",
    "acc_pubmed = []\n",
    "acc2_pubmed = []\n",
    "\n",
    "acc_citeseer = []\n",
    "acc2_citeseer = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d6047d38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-1.125551</td>\n",
       "      <td>-5.463236</td>\n",
       "      <td>80.0</td>\n",
       "      <td>79.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-1.392733</td>\n",
       "      <td>-1.483720</td>\n",
       "      <td>1049.0</td>\n",
       "      <td>1049.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1.183323</td>\n",
       "      <td>-1.345793</td>\n",
       "      <td>554.0</td>\n",
       "      <td>554.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-0.889518</td>\n",
       "      <td>-1.342498</td>\n",
       "      <td>365.0</td>\n",
       "      <td>645.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-0.728295</td>\n",
       "      <td>-1.034265</td>\n",
       "      <td>2452.0</td>\n",
       "      <td>2079.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5724</th>\n",
       "      <td>-0.035668</td>\n",
       "      <td>0.075141</td>\n",
       "      <td>2223.0</td>\n",
       "      <td>1682.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5725</th>\n",
       "      <td>-0.003204</td>\n",
       "      <td>0.075864</td>\n",
       "      <td>1591.0</td>\n",
       "      <td>2141.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5726</th>\n",
       "      <td>-0.004402</td>\n",
       "      <td>0.083183</td>\n",
       "      <td>2063.0</td>\n",
       "      <td>2063.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5727</th>\n",
       "      <td>-0.039464</td>\n",
       "      <td>0.100879</td>\n",
       "      <td>376.0</td>\n",
       "      <td>662.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5728</th>\n",
       "      <td>-0.014229</td>\n",
       "      <td>0.120671</td>\n",
       "      <td>563.0</td>\n",
       "      <td>352.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5729 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0         1       2       3\n",
       "0    -1.125551 -5.463236    80.0    79.0\n",
       "1    -1.392733 -1.483720  1049.0  1049.0\n",
       "2    -1.183323 -1.345793   554.0   554.0\n",
       "3    -0.889518 -1.342498   365.0   645.0\n",
       "4    -0.728295 -1.034265  2452.0  2079.0\n",
       "...        ...       ...     ...     ...\n",
       "5724 -0.035668  0.075141  2223.0  1682.0\n",
       "5725 -0.003204  0.075864  1591.0  2141.0\n",
       "5726 -0.004402  0.083183  2063.0  2063.0\n",
       "5727 -0.039464  0.100879   376.0   662.0\n",
       "5728 -0.014229  0.120671   563.0   352.0\n",
       "\n",
       "[5729 rows x 4 columns]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "367e2763",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [00:39<00:00,  2.51it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_cora = cora_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_citeseer = citeseer_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_citeseer = citeseer_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "\n",
    "\n",
    "    nis_cora = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                           from_index=from_index_cora, to_index=to_index_cora)\n",
    "    nis_cora.remove_edges_sgc_from_influence()\n",
    "    feat_removed_cora = nis_cora.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_pubmed = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                           from_index=from_index_pubmed, to_index=to_index_pubmed)\n",
    "    nis_pubmed.remove_edges_sgc_from_influence()\n",
    "    feat_removed_pubmed = nis_pubmed.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_citeseer = EdgeInfluenceSGC(graph = graph_citeseer, feature=feat_citeseer, \n",
    "                           from_index=from_index_citeseer, to_index=to_index_citeseer)\n",
    "    nis_citeseer.remove_edges_sgc_from_influence()\n",
    "    feat_removed_citeseer = nis_citeseer.calculate_modified_features()\n",
    "\n",
    "    \n",
    "    lr_cora = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    train_x_cora = feat_removed_cora[train_mask_cora == 1].numpy()\n",
    "    lr_cora.fit(train_x_cora, train_y_cora, sample_weight=None, verbose=False)\n",
    "    acc_cora.append(np.mean(lr_cora.model.predict(test_x_cora) == test_y_cora))\n",
    "    acc2_cora.append(np.mean(lr_cora.model.predict(val_x_cora) == val_y_cora))\n",
    "\n",
    "\n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_2, fit_intercept=True)\n",
    "    train_x_pubmed = feat_removed_pubmed[train_mask_pubmed == 1].numpy()\n",
    "    lr_pubmed.fit(train_x_pubmed, train_y_pubmed, sample_weight=None, verbose=False)\n",
    "    acc_pubmed.append(np.mean(lr_pubmed.model.predict(test_x_pubmed) == test_y_pubmed))\n",
    "    acc2_pubmed.append(np.mean(lr_pubmed.model.predict(val_x_pubmed) == val_y_pubmed))\n",
    "\n",
    "\n",
    "    lr_citeseer = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_3, fit_intercept=True)\n",
    "    train_x_citeseer = feat_removed_citeseer[train_mask_citeseer == 1].numpy()\n",
    "    lr_citeseer.fit(train_x_citeseer, train_y_citeseer, sample_weight=None, verbose=False)\n",
    "    acc_citeseer.append(np.mean(lr_citeseer.model.predict(test_x_citeseer) == test_y_citeseer))\n",
    "    acc2_citeseer.append(np.mean(lr_citeseer.model.predict(val_x_citeseer) == val_y_citeseer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "1ee38511",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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PgCefvppRISlS5dy7NgxkpOTee655+jTJ2PhKrOEhAT69Onj9bxJkybxyiuvICK0bNmSyZMnc/DgQUaOHMmOHTsAeOedd6hbty69evVi/fr1ALzyyiskJCTw9NNP07lzZ6688kqWLVvGTTfdRJMmTXjuuedISkqievXqTJ06lVq1apGQkMD999/PqlWrEBGeeuopjh8/zvr16/n3v/8NwPvvv8+mTZt47bXXLujXa4wpOr4MELFAfY/tUJySgqfhwIvqzPexXUR2As2An1V1H4CqHhKR2ThVVpkChKqOA8aBM9VGgT/FBRo4cCCjR48+HyBmzJjB119/zYMPPphpbQVvs6J6CggIyPWaDAB//etf6dSpE7NnzyY1NZWEhASOHTuW7T2OHz/Od999B8CxY8f46aefEBE++OADXnrpJV599VWeffZZgoODWbdu3fnjypUrR8uWLXnppZfw9/dnwoQJvPfeexf66zPGFCFfBoiVQGMRCQf2AgOB2zIcsxvoCnwvIrWApsAOEakIlFHVePd1N+CZC85RNt/0faV169bnZ2s9fPgwVatWpU6dOjz44IMsXbqUMmXKnF9boXbt2tle69yaDBnPy2pNhsWLFzNp0iQA/Pz8CA4OzjFADBgw4Pzr2NhYBgwYwP79+0lKSiI8PByARYsWMX369PPHVa1aFYAuXbowd+5cmjdvTnJyMpGRkXn8bRljihOfBQhVTRGRUcB8wA8Yr6obRGSkm/4u8CwwUUTW4VRJjVHVOBFpCMx2v1GXBT5W1a99lVdf69u3LzNnzuTAgQMMHDgwy7UVcpLXNRm88Vz/AbJfA+L+++/noYce4qabbuLbb7/l6aefBrJeW+Kuu+7ihRdeoFmzZjbFtzElgE/HQajqPFVtoqqNVPV5d9+7bnBAVfepajdVjVTVCFWd4u7foaqt3J8W5869WA0cOJDp06czc+ZM+vbtm+XaCjnJ65oMXbt2PT9teGpqKidPnqRWrVocOnSII0eOcPbsWebOnZvt/erVc/oVfPTRR+f3d+vWjTfffPP89rlSSfv27dmzZw8ff/yxTfFtTAlgI6kLQYsWLYiPj6devXrUqVOHwYMHs2rVKqKjo5k6der5tRVyktV5nmsytGrVioceegiA//znPyxZsoTIyEguv/xyNmzYgL+/P08++STt27enV69e2d776aefpl+/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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 = 50\n",
    "plt.plot(range(num), acc_cora[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.78, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b090defa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.813\n",
      "0.0\n",
      "\n"
     ]
    }
   ],
   "source": [
    "index_cora = np.where(acc2_cora == max(acc2_cora))\n",
    "print(np.array(acc_cora)[index_cora].mean())\n",
    "print(np.array(acc_cora)[index_cora].std())\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "5003b77d",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_cora = pd.DataFrame([acc_cora[0:num], acc2_cora[0:num], np.repeat(0.81, 50), np.repeat(0.83, 50)]).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/improve_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e3abd70c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "42b35e83",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "31aec62a",
   "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 = 50\n",
    "plt.plot(range(num), acc_pubmed[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.78, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "97fc79c8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.789\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "acc2_pubmed_new = acc2_pubmed[0:50]\n",
    "index_pubmed = np.where(acc2_pubmed_new == max(acc2_pubmed_new))\n",
    "print(np.array(acc_pubmed)[index_pubmed].mean())\n",
    "print(np.array(acc_pubmed)[index_pubmed].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "18355d0c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([9]),)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "index_pubmed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "d8a67232",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_pubmed = pd.DataFrame([acc_pubmed[0:num], acc2_pubmed[0:num], np.repeat(0.789, 50), np.repeat(0.799, 50)]).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/improve_accuracy/pubmed.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "ef3699ea",
   "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>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.790</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.797</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.796</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.794</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.794</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.792</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>0.793</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.810</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>0.791</td>\n",
       "      <td>0.800</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>11</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>13</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>0.786</td>\n",
       "      <td>0.800</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>14</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>0.786</td>\n",
       "      <td>0.800</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>0.792</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>16</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>19</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>0.791</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>0.788</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>21</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>0.785</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>22</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>0.782</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>23</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>24</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>0.791</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>26</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>27</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>0.788</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>28</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>29</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>30</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>0.787</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>31</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>0.787</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>32</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>0.787</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>34</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>0.787</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>35</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>0.786</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>36</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>0.786</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>0.784</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>38</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>0.786</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>40</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>41</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>0.788</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>42</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>0.789</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>43</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>44</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>45</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>0.792</td>\n",
       "      <td>0.804</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>46</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>0.790</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>47</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>0.784</td>\n",
       "      <td>0.798</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>48</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>0.784</td>\n",
       "      <td>0.798</td>\n",
       "      <td>0.789</td>\n",
       "      <td>0.799</td>\n",
       "      <td>49</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    test accuracy  val_accuracy    SGC  Best accuracy reported in paper  \\\n",
       "0           0.790         0.808  0.789                            0.799   \n",
       "1           0.797         0.802  0.789                            0.799   \n",
       "2           0.796         0.804  0.789                            0.799   \n",
       "3           0.790         0.804  0.789                            0.799   \n",
       "4           0.789         0.802  0.789                            0.799   \n",
       "5           0.794         0.802  0.789                            0.799   \n",
       "6           0.794         0.804  0.789                            0.799   \n",
       "7           0.792         0.808  0.789                            0.799   \n",
       "8           0.793         0.808  0.789                            0.799   \n",
       "9           0.789         0.810  0.789                            0.799   \n",
       "10          0.791         0.800  0.789                            0.799   \n",
       "11          0.790         0.802  0.789                            0.799   \n",
       "12          0.789         0.804  0.789                            0.799   \n",
       "13          0.789         0.802  0.789                            0.799   \n",
       "14          0.786         0.800  0.789                            0.799   \n",
       "15          0.786         0.800  0.789                            0.799   \n",
       "16          0.792         0.806  0.789                            0.799   \n",
       "17          0.789         0.808  0.789                            0.799   \n",
       "18          0.789         0.804  0.789                            0.799   \n",
       "19          0.789         0.804  0.789                            0.799   \n",
       "20          0.791         0.804  0.789                            0.799   \n",
       "21          0.788         0.804  0.789                            0.799   \n",
       "22          0.785         0.806  0.789                            0.799   \n",
       "23          0.782         0.804  0.789                            0.799   \n",
       "24          0.789         0.808  0.789                            0.799   \n",
       "25          0.789         0.808  0.789                            0.799   \n",
       "26          0.791         0.808  0.789                            0.799   \n",
       "27          0.789         0.806  0.789                            0.799   \n",
       "28          0.788         0.808  0.789                            0.799   \n",
       "29          0.790         0.808  0.789                            0.799   \n",
       "30          0.789         0.806  0.789                            0.799   \n",
       "31          0.787         0.802  0.789                            0.799   \n",
       "32          0.787         0.802  0.789                            0.799   \n",
       "33          0.789         0.804  0.789                            0.799   \n",
       "34          0.787         0.806  0.789                            0.799   \n",
       "35          0.787         0.806  0.789                            0.799   \n",
       "36          0.786         0.802  0.789                            0.799   \n",
       "37          0.786         0.804  0.789                            0.799   \n",
       "38          0.784         0.802  0.789                            0.799   \n",
       "39          0.786         0.804  0.789                            0.799   \n",
       "40          0.790         0.804  0.789                            0.799   \n",
       "41          0.790         0.804  0.789                            0.799   \n",
       "42          0.788         0.806  0.789                            0.799   \n",
       "43          0.789         0.808  0.789                            0.799   \n",
       "44          0.790         0.808  0.789                            0.799   \n",
       "45          0.790         0.808  0.789                            0.799   \n",
       "46          0.792         0.804  0.789                            0.799   \n",
       "47          0.790         0.802  0.789                            0.799   \n",
       "48          0.784         0.798  0.789                            0.799   \n",
       "49          0.784         0.798  0.789                            0.799   \n",
       "\n",
       "    number of edges to be removed  \n",
       "0                               0  \n",
       "1                               1  \n",
       "2                               2  \n",
       "3                               3  \n",
       "4                               4  \n",
       "5                               5  \n",
       "6                               6  \n",
       "7                               7  \n",
       "8                               8  \n",
       "9                               9  \n",
       "10                             10  \n",
       "11                             11  \n",
       "12                             12  \n",
       "13                             13  \n",
       "14                             14  \n",
       "15                             15  \n",
       "16                             16  \n",
       "17                             17  \n",
       "18                             18  \n",
       "19                             19  \n",
       "20                             20  \n",
       "21                             21  \n",
       "22                             22  \n",
       "23                             23  \n",
       "24                             24  \n",
       "25                             25  \n",
       "26                             26  \n",
       "27                             27  \n",
       "28                             28  \n",
       "29                             29  \n",
       "30                             30  \n",
       "31                             31  \n",
       "32                             32  \n",
       "33                             33  \n",
       "34                             34  \n",
       "35                             35  \n",
       "36                             36  \n",
       "37                             37  \n",
       "38                             38  \n",
       "39                             39  \n",
       "40                             40  \n",
       "41                             41  \n",
       "42                             42  \n",
       "43                             43  \n",
       "44                             44  \n",
       "45                             45  \n",
       "46                             46  \n",
       "47                             47  \n",
       "48                             48  \n",
       "49                             49  "
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_pubmed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4377de9d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "25721747",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_citeseer[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_citeseer[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.719, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.726, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_3)\n",
    "plt.ylim(0.7, 0.8)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "8c036b2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7337499999999999\n",
      "0.0021650635094610984\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([0.73 , 0.735, 0.735, 0.735])"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_citeseer2 = acc2_citeseer[0:100]\n",
    "index_citeseer = np.where(acc2_citeseer == max(acc2_citeseer))[0]\n",
    "print(np.array(acc_citeseer)[index_citeseer].mean())\n",
    "print(np.array(acc_citeseer)[index_citeseer].std())\n",
    "np.array(acc_citeseer)[index_citeseer]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "3d3148b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_citeseer = pd.DataFrame([acc_citeseer[0:num], acc2_citeseer[0:num], np.repeat(0.81, 50), np.repeat(0.83, 50)]).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/improve_accuracy/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "41faacf1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([58, 79, 80, 81])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "index_citeseer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "36e1b8c1",
   "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": 25,
   "id": "2d502c54",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([39]),)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_cora[11]\n",
    "np.where(acc2_cora == np.max(acc2_cora))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "a6b42d2e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.748"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc2_citeseer[20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "ee7a0bf8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.789"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5c701f16",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "674f63e6",
   "metadata": {},
   "outputs": [],
   "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": 29,
   "id": "f8a72914",
   "metadata": {},
   "outputs": [],
   "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": 30,
   "id": "bb002162",
   "metadata": {},
   "outputs": [],
   "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": 31,
   "id": "7ab735ed",
   "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": 32,
   "id": "cb60af17",
   "metadata": {},
   "outputs": [],
   "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": 33,
   "id": "d961b089",
   "metadata": {},
   "outputs": [],
   "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": 34,
   "id": "f216926c",
   "metadata": {},
   "outputs": [],
   "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": "eea0bbe2",
   "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
}
