{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8659f47f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n",
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import torch\n",
    "import dgl\n",
    "import numpy_ml\n",
    "import scipy\n",
    "import cupy as cp\n",
    "import cupyx\n",
    "\n",
    "from dgl import function as fn\n",
    "from dgl.base import DGLError\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from scipy.special import softmax, log_softmax\n",
    "from numpy.linalg import inv, pinv\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "from sklearn.metrics import log_loss\n",
    "from dataset import load_graph_dataset\n",
    "\n",
    "from model_node_influence import NodeInfluenceSGC\n",
    "\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork, fast_hess, fast_hess_cuda, fast_get_inv_hvp_cuda\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.linalg import cho_solve, cho_factor\n",
    "from model_edge_influence import EdgeInfluenceSGC, generate_remove_index_train\n",
    "from tqdm import tqdm\n",
    "\n",
    "from sklearnex import patch_sklearn, config_context\n",
    "patch_sklearn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b1e55d20",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set = 'cora'\n",
    "# l2_term = 0.01\n",
    "l2_term = 0.01\n",
    "# batch_edges = 1\n",
    "num_layer = 2\n",
    "\n",
    "# data_set = 'pubmed'\n",
    "# l2_term = 0.004\n",
    "# num_layer = 2\n",
    "\n",
    "# data_set = 'citeseer'\n",
    "# l2_term = 0.003\n",
    "# num_layer = 2\n",
    "\n",
    "# data_set = 'reddit'\n",
    "# l2_term = 0.99\n",
    "# num_layer = 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "176639f1",
   "metadata": {},
   "source": [
    "##### 1, load data, convert to one hot encoding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c28d984a",
   "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"
     ]
    }
   ],
   "source": [
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset(data_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "46a44719",
   "metadata": {},
   "outputs": [],
   "source": [
    "feat0 = feat.clone()\n",
    "degs = graph.in_degrees().float().clamp(min = 1)\n",
    "norm = torch.pow(degs, -0.5)\n",
    "norm = norm.to(feat0.device).unsqueeze(1)\n",
    "\n",
    "for _ in range(num_layer):\n",
    "    feat0 = feat0 * norm\n",
    "    graph.ndata['h'] = feat0\n",
    "    graph.update_all(fn.copy_u('h', 'm'),\n",
    "                     fn.sum('m', 'h'))\n",
    "    feat0 = graph.ndata.pop('h')\n",
    "    feat0 = feat0 * norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cac49d64",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x = feat0[train_mask].numpy().astype(np.float32)\n",
    "train_y = labels[train_mask].numpy().astype(np.float32)\n",
    "\n",
    "val_x = feat0[val_mask].numpy().astype(np.float32)\n",
    "val_y = labels[val_mask].numpy().astype(np.float32)\n",
    "\n",
    "train_node_idx = torch.where(train_mask == 1)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b8cc65bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# convert to one-hot labels\n",
    "enc = OneHotEncoder(handle_unknown='ignore')\n",
    "enc.fit(train_y.reshape(-1, 1))\n",
    "\n",
    "one_hot_labels_train = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "one_hot_labels_val = enc.transform(val_y.reshape(-1, 1)).toarray()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aaa5d78f",
   "metadata": {},
   "source": [
    "##### 2, Remove a single node, remove the propogated node feature as well as it connected edges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "dae55e22",
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"retrieve all edges connected to traing nodes\"\"\"\n",
    "def generate_remove_index_train_all(from_indexes, to_indexes, train_mask):\n",
    "    train_index = torch.where(train_mask == 1)[0]\n",
    "    remove_from_list = []\n",
    "    remove_to_list = []\n",
    "    for i in tqdm(range(len(train_index))):\n",
    "        f_index = train_index[i]\n",
    "        to_index_list = torch.where(from_indexes == f_index)[0]\n",
    "        for to_index_e in to_index_list:\n",
    "            j = to_index_e\n",
    "            t_index = to_indexes[j]\n",
    "\n",
    "            remove_from_list.append(f_index)\n",
    "            remove_to_list.append(t_index)\n",
    "\n",
    "    return torch.tensor(remove_from_list), torch.tensor(remove_to_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e78ab03b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████| 140/140 [00:00<00:00, 18026.73it/s]\n"
     ]
    }
   ],
   "source": [
    "from_indexes, to_indexes = graph.edges()\n",
    "\n",
    "f_l, t_l = generate_remove_index_train_all(from_indexes, to_indexes, train_mask)\n",
    "\n",
    "acctual_influence_node_features = []\n",
    "acctual_influence_edges = []\n",
    "\n",
    "predict_influence_node_features = []\n",
    "predict_influence_edges = []\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a40cc9cd",
   "metadata": {},
   "source": [
    "##### 2.1 train the original data, calculate the hessian matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d17dd3dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.76it/s]\n"
     ]
    }
   ],
   "source": [
    "lr_origin = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "\n",
    "lr_origin.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "\n",
    "logits_val_y_origin = val_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "logits_train_y_origin = train_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "ori_val_loss, ave_ori_val_loss = lr_origin.log_loss(logits_val_y_origin, one_hot_labels_val, l2_reg=True)\n",
    "\n",
    "# numpy_theoritic_loss = log_loss(val_y, softmax(logits_val_y_origin, axis=1))\n",
    "# # set l2_reg to False, verify the correctness of calculations\n",
    "# assert np.allclose(numpy_theoritic_loss, ave_ori_val_loss)\n",
    "\n",
    "val_loss_total_grad_orig, val_loss_indiv_grad_orig = lr_origin.grad(val_x, \n",
    "                                                                    logits_val_y_origin,\n",
    "                                                                    one_hot_labels_val, l2_reg = True)\n",
    "\n",
    "hess = lr_origin.hess_cuda(train_x, logits_train_y_origin, l2_reg = True)\n",
    "\n",
    "loss_grad_hvp = fast_get_inv_hvp_cuda(hess, val_loss_total_grad_orig.T, cholskey=True)\n",
    "\n",
    "loss_grad_hvp = cp.asnumpy(loss_grad_hvp)\n",
    "del hess"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "50e904c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time\n",
    "time_infl = []\n",
    "time_retrain = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7e4832c9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 140/140 [00:13<00:00, 10.11it/s]\n"
     ]
    }
   ],
   "source": [
    "acctual_influence_1 = []\n",
    "acctual_influence_2 = []\n",
    "\n",
    "predict_influence_1 = []\n",
    "predict_influence_2 = []\n",
    "\n",
    "for k in tqdm(range(len(train_node_idx))):\n",
    "    \n",
    "    node_id = train_node_idx.numpy()[k]\n",
    "    nis = NodeInfluenceSGC(graph = graph, feature=feat, node_index=node_id)\n",
    "    \n",
    "    # 2, remove the edges, calculate the perturbated feature\n",
    "    nis.remove_edges_sgc()\n",
    "    feat_removed1 = nis.calculate_modified_features()\n",
    "\n",
    "    extra_index = torch.unique(torch.where(feat0 != feat_removed1)[0])\n",
    "    \n",
    "    \n",
    "    extra_index_train = torch.tensor(\n",
    "        [extra_index[i] for i in range(len(extra_index)) if extra_index[i] in train_node_idx]).numpy()\n",
    "    \n",
    "    extra_index_train_in_train = [\n",
    "        np.where(train_node_idx.numpy() == extra_index_train[j])[0][0] for j in range(len(extra_index_train))]\n",
    "    \n",
    "    # 1, we need to remove the changed node feature from the perturbated feature, \n",
    "    # let it not added to the original feature\n",
    "    \n",
    "    \n",
    "    \"\"\"modified node features\"\"\"\n",
    "    extra_index_train_remove_node = extra_index_train.copy()\n",
    "    relative_node_id = np.where(extra_index_train_remove_node == node_id)[0]\n",
    "    extra_index_train_remove_node = np.delete(extra_index_train_remove_node, relative_node_id)\n",
    "    feat_to_be_added = feat_removed1[extra_index_train_remove_node].numpy()\n",
    "    \n",
    "    \"\"\"index corresponding to modified node features\"\"\"\n",
    "    perturb_index = extra_index_train_in_train\n",
    "    added_index = perturb_index.copy()\n",
    "    added_index.remove(k)\n",
    "\n",
    "    \n",
    "    \n",
    "    train_x_new = feat_to_be_added\n",
    "    train_y_new = train_y[added_index]\n",
    "    \n",
    "    train_x_orig = np.concatenate([train_x, train_x_new])\n",
    "    train_y_orig = np.concatenate([train_y, train_y_new])\n",
    "    \n",
    "    one_hot_labels_train_0 = enc.transform(train_y_orig.reshape(-1, 1)).toarray()\n",
    "    logits_train_y_origin_0 = train_x_orig @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    train_total_grad_orig, train_indiv_grad_orig = lr_origin.grad(train_x_orig, \n",
    "                                            logits_train_y_origin_0, \n",
    "                                            one_hot_labels_train_0, l2_reg = True)\n",
    "    \n",
    "\n",
    "    start_time = time.time()\n",
    "    pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "    time_infl.append(time.time() - start_time)\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    weight_3 = np.ones(len(train_x_orig))\n",
    "    weight_3[perturb_index] = 0 # 1...0...11\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    lr_new_2 = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "    train_x_delete_2 = train_x_orig[weight_3 == 1]\n",
    "    train_y_delete_2 = train_y_orig[weight_3 == 1]\n",
    "    \n",
    "    start_time = time.time()\n",
    "    lr_new_2.fit(train_x_delete_2, train_y_delete_2)\n",
    "    time_retrain.append(time.time() - start_time)\n",
    "    \n",
    "    logits_val_y_new_2 = val_x @ lr_new_2.model.coef_.T + lr_new_2.model.intercept_\n",
    "    new_ori_val_loss_2, _ = lr_new_2.log_loss(logits_val_y_new_2, one_hot_labels_val, l2_reg = True)\n",
    "    \n",
    "    predict_influence_1.append(np.sum(pred_infl[perturb_index]) - np.sum(pred_infl[len(train_x):]))\n",
    "    acctual_influence_1.append(new_ori_val_loss_2 - ori_val_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "465e25a5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "low_limit = -10\n",
    "up_limit = 10\n",
    "\n",
    "sns.set_theme()\n",
    "sns.set_style(\"whitegrid\")\n",
    "low_limit = -10\n",
    "up_limit = 10\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "plt.axis('square')\n",
    "plt.xlabel('Act. Influence')\n",
    "plt.ylabel('Pred. Influence')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(low_limit, up_limit)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "0b1bcb39",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=0.9811812556034201, pvalue=1.8787516837091622e-100)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(np.array(acctual_influence_1)[np.array(acctual_influence_1) !=0], np.array(predict_influence_1)[np.array(predict_influence_1) !=0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "cfedd202",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=0.9811812556034201, pvalue=1.8787516837091622e-100)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(acctual_influence_1, predict_influence_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "359ab0da",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data1 = pd.DataFrame([time_infl[i] / time_retrain[i] for i in range(len(time_infl))])\n",
    "# data1.to_csv('running time/citeseer_running_time.csv', header = None, index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "20a0053f",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame([acctual_influence_1, predict_influence_1]).T\n",
    "df.columns = ['acctual_influence', 'predict_influence']\n",
    "# df.to_csv('complete_node/' +data_set + '.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "2062e018",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pd.read_csv('complete_node/cora_flip.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "701a13ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138]"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "added_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "c8c73f14",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "139"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "k"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "019bc8ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138, 139]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "perturb_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "104dd1f5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(143, 1433)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_x_orig.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "9312668f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       0., 0., 0., 0., 1., 1., 1.])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weight_3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "5c09b764",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([136, 137, 138, 139]),)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.where(weight_3 == 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "e08dd2ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138, 139]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "perturb_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f428842",
   "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
}
