{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "afc62093",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from dgl import function as fn\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "from dataset import load_graph_dataset\n",
    "from tqdm import tqdm\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from train import train_preprocessed_data\n",
    "from model_edge_influence import EdgeInfluenceSGC\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9bcc2a4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set_1 = 'cora'\n",
    "l2_term_1 = 0.005\n",
    "# l2_term_1 = 0.01\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": 3,
   "id": "dd96c5a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_cora = train_preprocessed_data(data_name = data_set_1, k = num_layer)\n",
    "train_x_cora, train_y_cora, test_x_cora, test_y_cora, val_x_cora, val_y_cora = loader_cora.load_graph_to_tabular()\n",
    "graph_cora, feat_cora, labels_cora, train_mask_cora, val_mask_cora, test_mask_cora, number_classes_cora = load_graph_dataset(data_set_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5130afd9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 19717\n",
      "  NumEdges: 88651\n",
      "  NumFeats: 500\n",
      "  NumClasses: 3\n",
      "  NumTrainingSamples: 60\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_pubmed = train_preprocessed_data(data_name = data_set_2, k = num_layer)\n",
    "train_x_pubmed, train_y_pubmed, test_x_pubmed, test_y_pubmed, val_x_pubmed, val_y_pubmed = loader_pubmed.load_graph_to_tabular()\n",
    "graph_pubmed, feat_pubmed, labels_pubmed, train_mask_pubmed, val_mask_pubmed, test_mask_pubmed, number_classes_pubmed = load_graph_dataset(data_set_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "221aaa5b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n",
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "loader_citeseer = train_preprocessed_data(data_name = data_set_3, k = num_layer)\n",
    "train_x_citeseer, train_y_citeseer, test_x_citeseer, test_y_citeseer, val_x_citeseer, val_y_citeseer = loader_citeseer.load_graph_to_tabular()\n",
    "graph_citeseer, feat_citeseer, labels_citeseer, train_mask_citeseer, val_mask_citeseer, test_mask_citeseer, number_classes_citeseer = load_graph_dataset(data_set_3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1f3764e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora_infl = pd.read_csv('result_data/cora_edge_influence.csv', header = None)\n",
    "cora_infl = cora_infl.loc[cora_infl[0] < 0]\n",
    "cora_infl = cora_infl.sort_values([1])\n",
    "cora_infl.index = range(len(cora_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "af1b7b5c",
   "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])\n",
    "pubmed_infl.index = range(len(pubmed_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "25a0724a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pubmed_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "7241cb9e",
   "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])\n",
    "citeseer_infl.index = range(len(citeseer_infl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "dbb3f160",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 100\n",
    "i = 2\n",
    "\n",
    "acc_cora = []\n",
    "acc2_cora = []\n",
    "\n",
    "acc_pubmed = []\n",
    "acc2_pubmed = []\n",
    "\n",
    "acc_citeseer = []\n",
    "acc2_citeseer = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bf440af0",
   "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.144531</td>\n",
       "      <td>-6.955653</td>\n",
       "      <td>1834.0</td>\n",
       "      <td>2291.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-1.943359</td>\n",
       "      <td>-2.365344</td>\n",
       "      <td>836.0</td>\n",
       "      <td>1548.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-1.937460</td>\n",
       "      <td>-2.028468</td>\n",
       "      <td>1854.0</td>\n",
       "      <td>2297.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-1.872206</td>\n",
       "      <td>-1.887985</td>\n",
       "      <td>2519.0</td>\n",
       "      <td>2287.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-1.247726</td>\n",
       "      <td>-1.824752</td>\n",
       "      <td>1377.0</td>\n",
       "      <td>671.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>7357</th>\n",
       "      <td>-0.017567</td>\n",
       "      <td>0.080457</td>\n",
       "      <td>2333.0</td>\n",
       "      <td>1883.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7358</th>\n",
       "      <td>-0.030186</td>\n",
       "      <td>0.092499</td>\n",
       "      <td>2242.0</td>\n",
       "      <td>2246.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7359</th>\n",
       "      <td>-0.037192</td>\n",
       "      <td>0.100747</td>\n",
       "      <td>2090.0</td>\n",
       "      <td>2442.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7360</th>\n",
       "      <td>-0.011834</td>\n",
       "      <td>0.119321</td>\n",
       "      <td>195.0</td>\n",
       "      <td>194.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7361</th>\n",
       "      <td>-0.027821</td>\n",
       "      <td>0.135753</td>\n",
       "      <td>2101.0</td>\n",
       "      <td>2159.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>7362 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0         1       2       3\n",
       "0    -1.144531 -6.955653  1834.0  2291.0\n",
       "1    -1.943359 -2.365344   836.0  1548.0\n",
       "2    -1.937460 -2.028468  1854.0  2297.0\n",
       "3    -1.872206 -1.887985  2519.0  2287.0\n",
       "4    -1.247726 -1.824752  1377.0   671.0\n",
       "...        ...       ...     ...     ...\n",
       "7357 -0.017567  0.080457  2333.0  1883.0\n",
       "7358 -0.030186  0.092499  2242.0  2246.0\n",
       "7359 -0.037192  0.100747  2090.0  2442.0\n",
       "7360 -0.011834  0.119321   195.0   194.0\n",
       "7361 -0.027821  0.135753  2101.0  2159.0\n",
       "\n",
       "[7362 rows x 4 columns]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cora_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6d5e7998",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 100/100 [00:41<00:00,  2.41it/s]\n"
     ]
    }
   ],
   "source": [
    "for i in tqdm(range(n)):\n",
    "\n",
    "    from_index_cora = cora_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_cora = cora_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_pubmed = pubmed_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_pubmed = pubmed_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "    from_index_citeseer = citeseer_infl.loc[0:i][2].values.astype(int)\n",
    "    to_index_citeseer = citeseer_infl.loc[0:i][3].values.astype(int)\n",
    "\n",
    "\n",
    "\n",
    "    nis_cora = EdgeInfluenceSGC(graph = graph_cora, feature=feat_cora, \n",
    "                           from_index=from_index_cora, to_index=to_index_cora)\n",
    "    nis_cora.remove_edges_sgc_from_influence()\n",
    "    feat_removed_cora = nis_cora.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_pubmed = EdgeInfluenceSGC(graph = graph_pubmed, feature=feat_pubmed, \n",
    "                           from_index=from_index_pubmed, to_index=to_index_pubmed)\n",
    "    nis_pubmed.remove_edges_sgc_from_influence()\n",
    "    feat_removed_pubmed = nis_pubmed.calculate_modified_features()\n",
    "\n",
    "\n",
    "    nis_citeseer = EdgeInfluenceSGC(graph = graph_citeseer, feature=feat_citeseer, \n",
    "                           from_index=from_index_citeseer, to_index=to_index_citeseer)\n",
    "    nis_citeseer.remove_edges_sgc_from_influence()\n",
    "    feat_removed_citeseer = nis_citeseer.calculate_modified_features()\n",
    "\n",
    "    \n",
    "    lr_cora = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_1, fit_intercept=True)\n",
    "    train_x_cora = feat_removed_cora[train_mask_cora == 1].numpy()\n",
    "    lr_cora.fit(train_x_cora, train_y_cora, sample_weight=None, verbose=False)\n",
    "    acc_cora.append(np.mean(lr_cora.model.predict(test_x_cora) == test_y_cora))\n",
    "    acc2_cora.append(np.mean(lr_cora.model.predict(val_x_cora) == val_y_cora))\n",
    "\n",
    "\n",
    "    lr_pubmed = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_2, fit_intercept=True)\n",
    "    train_x_pubmed = feat_removed_pubmed[train_mask_pubmed == 1].numpy()\n",
    "    lr_pubmed.fit(train_x_pubmed, train_y_pubmed, sample_weight=None, verbose=False)\n",
    "    acc_pubmed.append(np.mean(lr_pubmed.model.predict(test_x_pubmed) == test_y_pubmed))\n",
    "    acc2_pubmed.append(np.mean(lr_pubmed.model.predict(val_x_pubmed) == val_y_pubmed))\n",
    "\n",
    "\n",
    "    lr_citeseer = SimplifiedGraphNeuralNetwork(l2_reg=l2_term_3, fit_intercept=True)\n",
    "    train_x_citeseer = feat_removed_citeseer[train_mask_citeseer == 1].numpy()\n",
    "    lr_citeseer.fit(train_x_citeseer, train_y_citeseer, sample_weight=None, verbose=False)\n",
    "    acc_citeseer.append(np.mean(lr_citeseer.model.predict(test_x_citeseer) == test_y_citeseer))\n",
    "    acc2_citeseer.append(np.mean(lr_citeseer.model.predict(val_x_citeseer) == val_y_citeseer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "daa67361",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tWqB2//5z3+evZy7c9ttt9GyZUs6derEihUrWLNmDe+99x49e/bMLmAHlr/66qt55plnAHjmmWfo318Pwosca0rUEcTB/tI/UtydoUOHcu211+aJzZ49m0mTJjF06FA6d+6cfXQQZdeuXVx33XXMmjWLevXqcffdd7Nr1y7yezLe3SNvLS1dujT79+/P3maiihUrZr8fO3Ys69atY/bs2aSmptKgQYPs/UVtt127dixbtowPPviAffv20bx583zbIiJHJx1BxKxy5cps27Yte/r8889n1KhRbN++HYAVK1awdu1aVq5cSYUKFejbty8333wzn3/+eeT6Bxz4Mq9evTrbt29nwoQJABx33HHUrVuXV199FYDdu3ezc+dOOnfuzKhRo7IveB84xdSgQQNmz54NkL2NKFu2bOGEE04gNTWVadOm8c03QQ/BHTt2ZPz48WzYsCHHdgGuuOIKLr30Uh09iByjStQRRDJUq1aNdu3a0bx5c7p27cqDDz7IggULOPvsYIjtSpUq8dxzz7F48WJuueUWSpUqRWpqKiNGjABgwIABdO3alVq1ajFt2rTs7R5//PFcc801tGjRggYNGnD66adnx8aMGcO1117LnXfeSWpqKi+++CJdunQhIyODtm3bUqZMGbp168b999/PzTffTK9evRgzZgznnXdevu247LLL6N69O23btiU9PZ0DAzM1a9aMP/7xj5x77rmkpKTQunVrRo8enb3O7bffzqWXXnq4f6wicgQU+876FixYQNOmTZOUUck2YcIEXnvtNcaMGRMZ12cjknwlurM+SY5Bgwbx1ltvMWnSpGSnIiKHSAVCYvGPf/wj2SmIyA+ki9QiIhJJBUJERCKpQIiISKRYC4SZdTGzhWa22MyGRMTTzOwNM/ufmc0zs/4JsWVmNsfMMsxsVu51RUQkXrFdpDazFOAx4OdAJjDTzF539/kJi/0OmO/u3c2sBrDQzMa6+54w3sHd18eVo4iI5C/OI4gzgMXuviT8wh8H9Mi1jAOVLeiroRKwESjRfUtXqlQp2SmIiADxFog6wPKE6cxwXqLhQFNgJTAHuMHd94cxByab2WwzGxBjnhJBY0CISJzPQUQNOpz7se3zgQzgPOBk4F0z+9DdtwLt3H2lmZ0Qzv/S3afn2UlQPAYA1K9f/+AZvTUEVs8pajsO7sQW0PWBfMO33nor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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": 14,
   "id": "060c8410",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.811\n",
      "0.0\n",
      "\n"
     ]
    }
   ],
   "source": [
    "index_cora = np.where(acc2_cora == max(acc2_cora))\n",
    "print(np.array(acc_cora)[index_cora].mean())\n",
    "print(np.array(acc_cora)[index_cora].std())\n",
    "print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e57d379f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "num = 50\n",
    "plt.plot(range(num), acc_pubmed[0:num], label = 'test accuracy')\n",
    "plt.plot(range(num), acc2_pubmed[0:num], label = 'val_accuracy')\n",
    "plt.axhline(y=0.789, color='green', linestyle='--', label = 'SGC')\n",
    "plt.axhline(y=0.799, color='red', linestyle='--', label = 'sota')\n",
    "plt.xlabel('number of edges perturb')\n",
    "plt.ylabel('accuracy')\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.title(data_set_2)\n",
    "plt.ylim(0.78, 0.85)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8db964b6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.797\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "acc2_pubmed = acc_pubmed[0:20]\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": 17,
   "id": "f9031f79",
   "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": 18,
   "id": "5cb4521e",
   "metadata": {},
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "index 58 is out of bounds for axis 0 with size 20",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_7318/3031037063.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0macc_citeseer2\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0macc2_citeseer\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;36m20\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mindex_citeseer\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwhere\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0macc2_citeseer\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0macc2_citeseer\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----> 3\u001b[0;31m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0macc_citeseer2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mindex_citeseer\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m(\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      4\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0macc_citeseer2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mindex_citeseer\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstd\u001b[0m\u001b[0;34m(\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[1;32m      5\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0macc_citeseer\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mindex_citeseer\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mIndexError\u001b[0m: index 58 is out of bounds for axis 0 with size 20"
     ]
    }
   ],
   "source": [
    "acc_citeseer2 = acc2_citeseer[0:20]\n",
    "index_citeseer = np.where(acc2_citeseer == max(acc2_citeseer))\n",
    "print(np.array(acc_citeseer2)[index_citeseer].mean())\n",
    "print(np.array(acc_citeseer2)[index_citeseer].std())\n",
    "np.array(acc_citeseer)[index_citeseer]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f53c197",
   "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": null,
   "id": "631b2f53",
   "metadata": {},
   "outputs": [],
   "source": [
    "acc_cora[11]\n",
    "np.where(acc2_cora == np.max(acc2_cora))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1bbcf77a",
   "metadata": {},
   "outputs": [],
   "source": [
    "acc2_citeseer[20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a458b621",
   "metadata": {},
   "outputs": [],
   "source": [
    "acc_pubmed[13]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "133ca00c",
   "metadata": {},
   "source": [
    "##### Augmentation with less influential point"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc66b15d",
   "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": null,
   "id": "3c7a05c8",
   "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": null,
   "id": "253cd90a",
   "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": null,
   "id": "9fd16e39",
   "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": null,
   "id": "27dd1ed2",
   "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": null,
   "id": "ab4fb359",
   "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": null,
   "id": "9995831f",
   "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": "96d1b543",
   "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
}
