{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2bbd05c0",
   "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": 4,
   "id": "0bc2e448",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.01\n",
    "\n",
    "data_set_2 = 'pubmed'\n",
    "l2_term_2 = 0.004 # 0.001\n",
    "\n",
    "data_set_3 = 'citeseer'\n",
    "l2_term_3 = 0.003\n",
    "\n",
    "num_layer = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a0ae5eae",
   "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": 6,
   "id": "2f67274a",
   "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": 7,
   "id": "e43cf212",
   "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": 11,
   "id": "03e0886c",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl = pd.read_csv('result_data/cora_edge_influence_001.csv', header = None)\n",
    "cora_infl = cora_infl.loc[cora_infl[0] > 0]\n",
    "cora_infl = cora_infl.sort_values([1], ascending=False)\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "144744df",
   "metadata": {},
   "outputs": [],
   "source": [
    "pubmed_infl = pd.read_csv('result_data/pubmed_edge_influence.csv', header = None)\n",
    "pubmed_infl = pubmed_infl.loc[pubmed_infl[0] > 0]\n",
    "pubmed_infl = pubmed_infl.sort_values([1], ascending=False)\n",
    "pubmed_infl.index = range(len(pubmed_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "95daea5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "citeseer_infl = pd.read_csv('result_data/citeseer_edge_influence.csv', header = None)\n",
    "citeseer_infl = citeseer_infl.loc[citeseer_infl[0] > 0]\n",
    "citeseer_infl = citeseer_infl.sort_values([1], ascending=False)\n",
    "citeseer_infl.index = range(len(citeseer_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a19597a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "i = 2\n",
    "\n",
    "acc_cora = []\n",
    "acc2_cora = []\n",
    "\n",
    "acc_pubmed = []\n",
    "acc2_pubmed = []\n",
    "\n",
    "acc_citeseer = []\n",
    "acc2_citeseer = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e2c873bc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.697631</td>\n",
       "      <td>1.777291</td>\n",
       "      <td>2014.0</td>\n",
       "      <td>1281.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          0         1       2       3\n",
       "0  2.697631  1.777291  2014.0  1281.0"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl.loc[0:0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "f1789938",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [00:39<00:00,  2.50it/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": 18,
   "id": "258fb74a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_cora[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.7, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "662d1564",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.778\n",
      "0.0\n",
      "\n"
     ]
    }
   ],
   "source": [
    "index_cora = np.where(acc2_cora == min(acc2_cora))\n",
    "print(np.array(acc_cora)[index_cora].mean())\n",
    "print(np.array(acc_cora)[index_cora].std())\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1a8dedd3",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_47927/811900443.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'number of edges to be removed'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mindex\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolumns\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m'test accuracy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'val_accuracy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'SGC'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'Best accuracy reported in paper'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'number of edges to be removed'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 4\u001b[0;31m \u001b[0mdf_cora\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto_csv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'visulize/attack_on_accuracy/cora.csv'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/core/generic.py\u001b[0m in \u001b[0;36mto_csv\u001b[0;34m(self, path_or_buf, sep, na_rep, float_format, columns, header, index, index_label, mode, encoding, compression, quoting, quotechar, line_terminator, chunksize, date_format, doublequote, escapechar, decimal, errors, storage_options)\u001b[0m\n\u001b[1;32m   3464\u001b[0m         )\n\u001b[1;32m   3465\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3466\u001b[0;31m         return DataFrameRenderer(formatter).to_csv(\n\u001b[0m\u001b[1;32m   3467\u001b[0m             \u001b[0mpath_or_buf\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   3468\u001b[0m             \u001b[0mline_terminator\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mline_terminator\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/formats/format.py\u001b[0m in \u001b[0;36mto_csv\u001b[0;34m(self, path_or_buf, encoding, sep, columns, index_label, mode, compression, quoting, quotechar, line_terminator, chunksize, date_format, doublequote, escapechar, errors, storage_options)\u001b[0m\n\u001b[1;32m   1103\u001b[0m             \u001b[0mformatter\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfmt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1104\u001b[0m         )\n\u001b[0;32m-> 1105\u001b[0;31m         \u001b[0mcsv_formatter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msave\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1106\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1107\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mcreated_buffer\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/formats/csvs.py\u001b[0m in \u001b[0;36msave\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    235\u001b[0m         \"\"\"\n\u001b[1;32m    236\u001b[0m         \u001b[0;31m# apply compression and byte/text conversion\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 237\u001b[0;31m         with get_handle(\n\u001b[0m\u001b[1;32m    238\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    239\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/common.py\u001b[0m in \u001b[0;36mget_handle\u001b[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[0m\n\u001b[1;32m    700\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mencoding\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m\"b\"\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    701\u001b[0m             \u001b[0;31m# Encoding\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 702\u001b[0;31m             handle = open(\n\u001b[0m\u001b[1;32m    703\u001b[0m                 \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    704\u001b[0m                 \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'"
     ]
    }
   ],
   "source": [
    "df_cora = pd.DataFrame([acc_cora[0:num], acc2_cora[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_cora['number of edges to be removed'] = df_cora.index\n",
    "df_cora.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_cora.to_csv('visulize/attack_on_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "fee9d5d6",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_47927/4235208590.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mpd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mread_csv\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'visulize/attack_on_accuracy/cora.csv'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/util/_decorators.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m    309\u001b[0m                     \u001b[0mstacklevel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstacklevel\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    310\u001b[0m                 )\n\u001b[0;32m--> 311\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    312\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    313\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36mread_csv\u001b[0;34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, squeeze, prefix, mangle_dupe_cols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, error_bad_lines, warn_bad_lines, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options)\u001b[0m\n\u001b[1;32m    584\u001b[0m     \u001b[0mkwds\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkwds_defaults\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    585\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 586\u001b[0;31m     \u001b[0;32mreturn\u001b[0m \u001b[0m_read\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    587\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    588\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m_read\u001b[0;34m(filepath_or_buffer, kwds)\u001b[0m\n\u001b[1;32m    480\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    481\u001b[0m     \u001b[0;31m# Create the parser.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 482\u001b[0;31m     \u001b[0mparser\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mTextFileReader\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfilepath_or_buffer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    483\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    484\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mchunksize\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0miterator\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, f, engine, **kwds)\u001b[0m\n\u001b[1;32m    809\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"has_index_names\"\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"has_index_names\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    810\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 811\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_engine\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_make_engine\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mengine\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    812\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    813\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mclose\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/readers.py\u001b[0m in \u001b[0;36m_make_engine\u001b[0;34m(self, engine)\u001b[0m\n\u001b[1;32m   1038\u001b[0m             )\n\u001b[1;32m   1039\u001b[0m         \u001b[0;31m# error: Too many arguments for \"ParserBase\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1040\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mmapping\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mengine\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# type: ignore[call-arg]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1041\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1042\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m_failover_to_python\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/c_parser_wrapper.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, src, **kwds)\u001b[0m\n\u001b[1;32m     49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     50\u001b[0m         \u001b[0;31m# open handles\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 51\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_open_handles\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msrc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     52\u001b[0m         \u001b[0;32massert\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhandles\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     53\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/parsers/base_parser.py\u001b[0m in \u001b[0;36m_open_handles\u001b[0;34m(self, src, kwds)\u001b[0m\n\u001b[1;32m    220\u001b[0m         \u001b[0mLet\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mreaders\u001b[0m \u001b[0mopen\u001b[0m \u001b[0mIOHandles\u001b[0m \u001b[0mafter\u001b[0m \u001b[0mthey\u001b[0m \u001b[0mare\u001b[0m \u001b[0mdone\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mtheir\u001b[0m \u001b[0mpotential\u001b[0m \u001b[0mraises\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    221\u001b[0m         \"\"\"\n\u001b[0;32m--> 222\u001b[0;31m         self.handles = get_handle(\n\u001b[0m\u001b[1;32m    223\u001b[0m             \u001b[0msrc\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    224\u001b[0m             \u001b[0;34m\"r\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.8/site-packages/pandas/io/common.py\u001b[0m in \u001b[0;36mget_handle\u001b[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[0m\n\u001b[1;32m    700\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mencoding\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m\"b\"\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    701\u001b[0m             \u001b[0;31m# Encoding\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 702\u001b[0;31m             handle = open(\n\u001b[0m\u001b[1;32m    703\u001b[0m                 \u001b[0mhandle\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    704\u001b[0m                 \u001b[0mioargs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmode\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'visulize/attack_on_accuracy/cora.csv'"
     ]
    }
   ],
   "source": [
    "pd.read_csv('visulize/attack_on_accuracy/cora.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "03472794",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_pubmed[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.7, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "04d64d27",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_pubmed = pd.DataFrame([acc_pubmed[0:num], acc2_pubmed[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_pubmed['number of edges to be removed'] = df_pubmed.index\n",
    "df_pubmed.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_pubmed.to_csv('visulize/attack_on_accuracy/pubmed.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "a6a44ea7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# acc2_pubmed = acc_pubmed[0:100]\n",
    "# index_pubmed = np.where(acc2_pubmed == max(acc2_pubmed))\n",
    "# print(np.array(acc_pubmed)[index_pubmed].mean())\n",
    "# print(np.array(acc_pubmed)[index_pubmed].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "24744e0b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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evQoYWFhvPHGGyxcuJDy5ctnuvfw4cN55plnALjtttuYNWsWPXr04JZbbmHkyJH07t2bU6dOkZKSwg8//MA333zD8uXLCQ0N5dChQ2es27Jly1izZg1ly5YlKSmJGTNmUKpUKQ4cOMBll11Gz5492bBhAy+99BK//PIL5cuX59ChQ5QsWZL27dvz/fffc8MNNzB16lRuuukme2bDmPOMtTgKiHnz5jFv3jyaN2/OpZdeyl9//cWWLVto0qQJP/74I48//jhLly4lLCzsjPdauHAhbdq0oUmTJvz000+sX7+e48ePs2vXLnr37g04D9qFhoby448/cueddxIaGgpA2bJlz3j/a6+9Ni2dqvLkk0/StGlTOnXqxK5du9i7dy8//fQTffr0SQtsqenvueceJk6cCMDEiRO58847vb+JMabAshYHZNsyOFdUlSeeeIIhQ4ZkurZq1Spmz57NE088QefOndNaE96cOnWK++67j5UrV1K9enVGjRrFqVOnyGqFAFX1OgU2KCiIlJSUtHt6Kl68eNrrKVOmsH//flatWkVwcDA1a9ZMez9v923Xrh1RUVEsXryY5ORkGjdunGVdjDEFk7U48knJkiU5fvx42nGXLl2YMGECsbGxAOzatYt9+/YRExNDaGgot956K48++iirV6/2mj9V6od8+fLliY2NZfr06QCUKlWKatWq8c033wAQHx9PXFwcnTt3ZsKECWkD7aldVTVr1mTVqlUAaffw5ujRo1SsWJHg4GAWLlzI3387qzB37NiRadOmcfDgwXT3Bbj99tsZOHCgtTaMOU9ZiyOflCtXjnbt2tG4cWO6devGq6++ysaNG2nbti0AJUqU4NNPP2Xr1q089thjBAQEEBwczJgxYwAYPHgw3bp1o0qVKixcuDDtvqVLl+bee++lSZMm1KxZk1atWqVdmzx5MkOGDOGZZ54hODiYL7/8kq5duxIZGUnLli0pUqQI1113HS+//DKPPvoo/fr1Y/LkyVxzzTVZ1uOWW26hR48etGzZkoiICFI3zGrUqBFPPfUUV199NYGBgTRv3pxJkyal5Xn66acZOHBgXv9YjTHnQKFd5HDjxo1ccskl+VSiwm369OnMnDmTyZMne71u/zbGFAy2yKEpEB544AF++OEHZs+end9FMcacJQsc5pz63//+l99FMMbkkg2OG2OM8YkFDmOM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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 100\n",
    "plt.plot(range(num), acc_citeseer[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_citeseer[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.719, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.726, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_3)\n",
    "plt.ylim(0.6, 0.8)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "16062da6",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_citeseer = pd.DataFrame([acc_citeseer[0:num], acc2_citeseer[0:num], np.repeat(0.81, 100), np.repeat(0.83, 100)]).T\n",
    "df_citeseer['number of edges to be removed'] = df_citeseer.index\n",
    "df_citeseer.columns = ['test accuracy', 'val_accuracy', 'SGC', 'Best accuracy reported in paper', 'number of edges to be removed']\n",
    "df_citeseer.to_csv('visulize/attack_on_accuracy/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "0d199f82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>test accuracy</th>\n",
       "      <th>val_accuracy</th>\n",
       "      <th>SGC</th>\n",
       "      <th>Best accuracy reported in paper</th>\n",
       "      <th>number of edges to be removed</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>0.719</td>\n",
       "      <td>0.738</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.736</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>0.718</td>\n",
       "      <td>0.728</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>0.722</td>\n",
       "      <td>0.724</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>0.718</td>\n",
       "      <td>0.720</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>95</th>\n",
       "      <td>95</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.646</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>96</th>\n",
       "      <td>96</td>\n",
       "      <td>0.647</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>96</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>97</th>\n",
       "      <td>97</td>\n",
       "      <td>0.647</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>97</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>98</th>\n",
       "      <td>98</td>\n",
       "      <td>0.648</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>98</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>99</th>\n",
       "      <td>99</td>\n",
       "      <td>0.648</td>\n",
       "      <td>0.650</td>\n",
       "      <td>0.81</td>\n",
       "      <td>0.83</td>\n",
       "      <td>99</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>100 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "    Unnamed: 0  test accuracy  val_accuracy   SGC  \\\n",
       "0            0          0.719         0.738  0.81   \n",
       "1            1          0.720         0.736  0.81   \n",
       "2            2          0.718         0.728  0.81   \n",
       "3            3          0.722         0.724  0.81   \n",
       "4            4          0.718         0.720  0.81   \n",
       "..         ...            ...           ...   ...   \n",
       "95          95          0.650         0.646  0.81   \n",
       "96          96          0.647         0.650  0.81   \n",
       "97          97          0.647         0.650  0.81   \n",
       "98          98          0.648         0.650  0.81   \n",
       "99          99          0.648         0.650  0.81   \n",
       "\n",
       "    Best accuracy reported in paper  number of edges to be removed  \n",
       "0                              0.83                              0  \n",
       "1                              0.83                              1  \n",
       "2                              0.83                              2  \n",
       "3                              0.83                              3  \n",
       "4                              0.83                              4  \n",
       "..                              ...                            ...  \n",
       "95                             0.83                             95  \n",
       "96                             0.83                             96  \n",
       "97                             0.83                             97  \n",
       "98                             0.83                             98  \n",
       "99                             0.83                             99  \n",
       "\n",
       "[100 rows x 6 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.read_csv('visulize/attack_on_accuracy/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "5984069d",
   "metadata": {},
   "outputs": [],
   "source": [
    "perturb = []\n",
    "for j in range(100):\n",
    "    if (acc_cora[j] > acc_cora[0]) and (acc_pubmed[j] > acc_pubmed[0]) and (acc_citeseer[j] > acc_citeseer[0]):\n",
    "        perturb.append(j)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "890add08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0, 2, 3]),)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_cora[11]\n",
    "np.where(acc2_cora == np.max(acc2_cora))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "acdfd830",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.712"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc2_citeseer[20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "783f673b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.758"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "64cabbea",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "9e960c92",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:07<00:00,  6.73it/s]\n"
     ]
    }
   ],
   "source": [
    "down_weight = 0.5\n",
    "num = 50\n",
    "acc_cora_augment = []\n",
    "acc2_cora_augment = []\n",
    "\n",
    "\n",
    "cora_infl_0 = pd.read_csv('result_data/cora_edge_influence.csv', header = None)\n",
    "cora_infl_0 = cora_infl_0.loc[abs(cora_infl_0[1]) < 0.00005]\n",
    "cora_infl_0 = cora_infl_0.sort_values([1])\n",
    "cora_infl_0.index = range(len(cora_infl_0))\n",
    "\n",
    "from_index_cora_less_infl = cora_infl_0.loc[0:][2].values.astype(int)\n",
    "to_index_cora_less_infl = cora_infl_0.loc[0:][3].values.astype(int)\n",
    "nis_cora_less_infl = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                   from_index=from_index_cora_less_infl, to_index=to_index_cora_less_infl)\n",
    "nis_cora_less_infl.remove_edges_sgc_from_influence()\n",
    "feat_augment_cora = nis_cora_less_infl.calculate_modified_features()\n",
    "\n",
    "train_x_cora_augment_low_infl = feat_augment_cora[train_mask_cora == 1].numpy()\n",
    "index_augment = np.unique(np.where(train_x_cora != train_x_cora_augment_low_infl)[0])\n",
    "train_x_cora_extra = train_x_cora_augment_low_infl[index_augment]\n",
    "train_y_cora_extra = train_y_cora[index_augment]\n",
    "\n",
    "w1 = np.ones(train_x_cora_extra.shape[0] + train_x_cora.shape[0])\n",
    "w1[len(train_x_cora):] = down_weight\n",
    "\n",
    "for i in tqdm(range(num)):\n",
    "    from_index_cora = cora_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i][3].values.astype(int)\n",
    "    \n",
    "\n",
    "    \n",
    "    nis_cora = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                           from_index=from_index_cora, to_index=to_index_cora)\n",
    "    nis_cora.remove_edges_sgc_from_influence()\n",
    "    feat_removed_cora = nis_cora.calculate_modified_features()\n",
    "    \n",
    "    train_x_cora_remove_high_infl = feat_removed_cora[train_mask_cora == 1].numpy()\n",
    "    \n",
    "    \n",
    "    lr_cora = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    \n",
    "    train_x_cora_new = np.concatenate([train_x_cora_remove_high_infl, train_x_cora_extra])\n",
    "    train_y_cora_new = np.concatenate([train_y_cora, train_y_cora_extra])\n",
    "    \n",
    "    lr_cora.fit(train_x_cora_new, train_y_cora_new, sample_weight=w1, verbose=False)\n",
    "    acc_cora_augment.append(np.mean(lr_cora.model.predict(test_x_cora) == test_y_cora))\n",
    "    acc2_cora_augment.append(np.mean(lr_cora.model.predict(val_x_cora) == val_y_cora))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "291c3e60",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(range(num), acc_cora_augment[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_cora_augment[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.81, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.83, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_1)\n",
    "plt.ylim(0.78, 0.86)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "41b1cbd3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8042500000000001\n",
      "0.0011989578808281809\n"
     ]
    }
   ],
   "source": [
    "index_cora_augment = np.where(acc2_cora_augment == max(acc2_cora_augment))\n",
    "print(np.array(acc_cora_augment)[index_cora_augment].mean())\n",
    "print(np.array(acc_cora_augment)[index_cora_augment].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "e184d235",
   "metadata": {},
   "outputs": [],
   "source": [
    "down_weight = 0.1\n",
    "num = 50\n",
    "threshold = 0.00005\n",
    "acc_pubmed_augment = []\n",
    "acc2_pubmed_augment = []\n",
    "\n",
    "\n",
    "pubmed_infl_0 = pd.read_csv('result_data/pubmed_edge_influence.csv', header = None)\n",
    "pubmed_infl_0 = pubmed_infl_0.loc[abs(pubmed_infl_0[1]) < 0.00005]\n",
    "pubmed_infl_0 = pubmed_infl_0.sort_values([1])\n",
    "pubmed_infl_0.index = range(len(pubmed_infl_0))\n",
    "\n",
    "from_index_pubmed_less_infl = pubmed_infl_0.loc[0:][2].values.astype(int)\n",
    "to_index_pubmed_less_infl = pubmed_infl_0.loc[0:][3].values.astype(int)\n",
    "nis_pubmed_less_infl = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                   from_index=from_index_pubmed_less_infl, to_index=to_index_pubmed_less_infl)\n",
    "nis_pubmed_less_infl.remove_edges_sgc_from_influence()\n",
    "feat_augment_pubmed = nis_pubmed_less_infl.calculate_modified_features()\n",
    "\n",
    "train_x_pubmed_augment_low_infl = feat_augment_pubmed[train_mask_pubmed == 1].numpy()\n",
    "index_augment = np.unique(np.where(train_x_pubmed != train_x_pubmed_augment_low_infl)[0])\n",
    "train_x_pubmed_extra = train_x_pubmed_augment_low_infl[index_augment]\n",
    "train_y_pubmed_extra = train_y_pubmed[index_augment]\n",
    "\n",
    "w1 = np.ones(train_x_pubmed_extra.shape[0] + train_x_pubmed.shape[0])\n",
    "w1[len(train_x_pubmed):] = down_weight\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "d8a91b87",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:03<00:00, 14.65it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(num)):\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i][3].values.astype(int)\n",
    "    \n",
    "\n",
    "    \n",
    "    nis_pubmed = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                           from_index=from_index_pubmed, to_index=to_index_pubmed)\n",
    "    nis_pubmed.remove_edges_sgc_from_influence()\n",
    "    feat_removed_pubmed = nis_pubmed.calculate_modified_features()\n",
    "    \n",
    "    train_x_pubmed_remove_high_infl = feat_removed_pubmed[train_mask_pubmed == 1].numpy()\n",
    "    \n",
    "    \n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    \n",
    "    train_x_pubmed_new = np.concatenate([train_x_pubmed_remove_high_infl, train_x_pubmed_extra])\n",
    "    train_y_pubmed_new = np.concatenate([train_y_pubmed, train_y_pubmed_extra])\n",
    "    \n",
    "    lr_pubmed.fit(train_x_pubmed_new, train_y_pubmed_new, sample_weight=w1, verbose=False)\n",
    "    acc_pubmed_augment.append(np.mean(lr_pubmed.model.predict(test_x_pubmed) == test_y_pubmed))\n",
    "    acc2_pubmed_augment.append(np.mean(lr_pubmed.model.predict(val_x_pubmed) == val_y_pubmed))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "b87e7a89",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.plot(range(num), acc_pubmed_augment[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed_augment[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.75, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "99bb954d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.782\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "index_pubmed_augment = np.where(acc2_pubmed_augment == max(acc2_pubmed_augment))\n",
    "print(np.array(acc_pubmed_augment)[index_pubmed_augment].mean())\n",
    "print(np.array(acc_pubmed_augment)[index_pubmed_augment].std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8ab815fe",
   "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
}
