{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "12bdf549",
   "metadata": {},
   "outputs": [],
   "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": 18,
   "id": "f7ad3f3c",
   "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": 19,
   "id": "e943566d",
   "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": 20,
   "id": "f27b6cff",
   "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": 21,
   "id": "9597ad05",
   "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": 22,
   "id": "3623e5b1",
   "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": 23,
   "id": "3e1e77c7",
   "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": 24,
   "id": "df0199de",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pubmed_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "3201019c",
   "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": 26,
   "id": "e0624d7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# n = 100\n",
    "n= 500\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": 27,
   "id": "8cdca66c",
   "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": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "ae354758",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 500/500 [03:21<00:00,  2.48it/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": 30,
   "id": "acfef639",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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q1fn3nvvBWD06NGICAsWLODYsWNcuHCBF198kX790lau0ouLi6Nfv35uz/v888954403EBGaNGnCpEmTOHjwICNGjGD79u0AfPDBB1SuXJk+ffqwbt06AN544w3i4uIYPXo0HTt2pG3btvz1119ce+211K1blxdffJH4+HjKlSvHl19+SVhYGHFxcTzwwAMsX74cEeG5557j+PHjrFu3jrfffhuAjz76iI0bN/LWW29d0o9XKZV/vBkgYoCqLq/DsTUFV8OAV43N9xEtIjuA+sBSY8w+AGPMIRH5EdtklS5AGGPGA+PBptrI9bu4RIMGDWLkyJEpAWLy5MlMnz6dhx56KN3aCu6yoroKCAjweE0GgH//+9906NCBH3/8kcTEROLi4jh27Fim73H8+HHmz58PwLFjx/j7778RET7++GNee+013nzzTcaMGUNISAhr165NOc7f358mTZrw2muv4efnx6effsqHH354qT8+pVQ+8maAWAbUEZEawF5gEHBzmmN2A12AhSISBtQDtotIScDHGHPKed4deOGSS5TJN31vadasWUq21sOHD1OmTBkqVarEQw89xIIFC/Dx8UlZW6FixYqZXit5TYa052W0JsOcOXP4/PPPAfD19SUkJCTLADFw4MCU5zExMQwcOJD9+/cTHx9PjRo1AJg1axbffPNNynFlypQBoHPnzkydOpUGDRpw4cIFIiMjs/nTUkoVJF4LEMaYBBG5H/gD8AUmGGPWi8gIZ/84YAwwUUTWYpukHjfGxIpITeBH5xt1MeArY8x0b5XV2wYMGMCUKVM4cOAAgwYNynBthaxkd00Gd1zXf4DM14B44IEHePjhh7n22muZN28eo0ePBjJeW+LOO+/k5Zdfpn79+priW6lCwKvzIIwx04wxdY0xtYwxLznbxjnBAWPMPmNMd2NMpDGmsTHmC2f7dmNMU+fRKPncy9WgQYP45ptvmDJlCgMGDMhwbYWsZHdNhi5duqSkDU9MTOTkyZOEhYVx6NAhjhw5wvnz55k6dWqm71elih1X8Nlnn6Vs7969O2PHjk15nVwradOmDXv27OGrr77SFN9KFQI6kzoPNGrUiFOnTlGlShUqVarELbfcwvLly2nZsiVffvllytoKWcnoPNc1GZo2bcrDDz8MwH//+1/mzp1LZGQkLVq0YP369fj5+fHss8/Spk0b+vTp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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_cora[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.78, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "4182b545",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8135454545454546\n",
      "0.0006555547773570894\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": "96dae09c",
   "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": "b7692fca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12cbfab5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "8d860a45",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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/vnnNGrUiAMHDnDGGWdw6aWXsmnTJp566imWLVtGVFQUBw8eJDw8nMGDB/PNN9/wpz/9iRkzZnDFFVdonwelTjGagzjJfvjhB3744Qf69u3Laaedxu+//05iYiLx8fHMnTuXCRMmsGTJEiIiIio81oIFCxgwYADx8fHMnz+fjRs3cvToUXbv3s3ll18O2A5pISEhzJ07l5tvvpmQkBAAIiMjKzz+BRdcULSdMYZHHnmEXr16cf7557N7927279/P/PnzGTVqVFEAc25/66238u677wLw7rvvcvPNN7s/iVKqzmpQOYjynvRPFmMMDz/8MLfffnupdatXr2bOnDk8/PDDDBs2rCh34E5OTg533nknq1atonXr1kycOJGcnBzK6hlvjHHbtNTPz4/CwsKiY7oKDQ0tej19+nTS0tJYvXo1/v7+xMXFFZ3P3XEHDhxIcnIyixYtoqCggJ49e5Z5LUqpuklzEF4WHh7O0aNHi95feOGFvPPOO2RmZgKwe/duUlNT2bNnDyEhIVx33XU88MADrFmzxu3+Ts6beVRUFJmZmcyaNQuARo0aERsbyxdffAFAbm4uWVlZDBs2jHfeeaeowttZxBQXF8fq1asBio7hTkZGBs2bN8ff358FCxawc6cdIXjo0KHMnDmT9PT0YscFuOGGG7j66qs196DUKapB5SBqQ9OmTRk4cCA9e/ZkxIgR/Oc//2Hz5s2ceeaZAISFhfHBBx+QlJTEgw8+iI+PD/7+/rzxxhsAjB07lhEjRhATE8OCBQuKjtu4cWNuu+024uPjiYuLo3///kXrpk2bxu23386//vUv/P39+eSTTxg+fDhr164lISGBgIAARo4cydNPP80DDzzA6NGjmTZtGkOGDCnzOq699louueQSEhIS6NOnD86JmXr06ME//vEPBg0ahK+vL3379mXq1KlF+zz66KNcffXVNf2xKqVOgno/WN/mzZvp1q1bLaWoYZs1axZffvkl06ZNc7te/zZK1b4GPVifqh1333033377LXPmzKntpCilqkgDhPKKV155pbaToJSqJq2kVkop5ZYGCKWUUm5pgFBKKeWWBgillFJuaYBQSinllgaIOiYsLKy2k6CUUoAGCFUGnQNCKeXVfhAiMhx4CfAF3jbGPFNifQTwAdDGkZbnjTHvuqz3BVYBu40xF1c7Qd8+BPvWV/swxUTH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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.78, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "15c68342",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7922307692307692\n",
      "0.0011867114323493482\n"
     ]
    }
   ],
   "source": [
    "acc2_pubmed_new = acc2_pubmed[0:200]\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": "153e506a",
   "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": "e80596ca",
   "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": "e60fca71",
   "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": "c6aedd49",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "bcf50a6c",
   "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": 42,
   "id": "89f010ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.723\n",
      "0.0\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array([0.723])"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_citeseer2 = acc2_citeseer[0:50]\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": 41,
   "id": "bad35447",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'visulize/improve_accuracy/citeseer.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_11001/2592825719.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mdf_citeseer\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_citeseer\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_citeseer\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_citeseer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto_csv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'visulize/improve_accuracy/citeseer.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/improve_accuracy/citeseer.csv'"
     ]
    }
   ],
   "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": "043fa9cf",
   "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": "72b656d9",
   "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": "f4c8aa2f",
   "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": "f9d60745",
   "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": "97faca67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.789"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0463070",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "d65d275b",
   "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": "6e9934e7",
   "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": "25cfa4dc",
   "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": "ac062f84",
   "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": "d15bf8b0",
   "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": "c71b8171",
   "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": "f41ea970",
   "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": "82e2caab",
   "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
}
