{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f7fcd7ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n",
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import math\n",
    "import torch\n",
    "import dgl\n",
    "import numpy_ml\n",
    "import torch.nn.functional as F\n",
    "import tensorflow.compat.v1 as tf\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",
    "from model_node_influence import NodeInfluenceSGC\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork, fast_hess, fast_hess_cuda, fast_get_inv_hvp_cuda\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7412dd11",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "from sklearnex import patch_sklearn, config_context\n",
    "patch_sklearn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1522a3d6",
   "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": "code",
   "execution_count": 4,
   "id": "d4a0ca29",
   "metadata": {},
   "outputs": [],
   "source": [
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset(data_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e3e83771",
   "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": 8,
   "id": "328cee0e",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_x = feat0[train_mask].numpy().astype(np.float32)\n",
    "train_y = labels[train_mask].numpy().astype(np.float32)\n",
    "\n",
    "test_x = feat0[test_mask].numpy().astype(np.float32)\n",
    "test_y = labels[test_mask].numpy().astype(np.float32)\n",
    "\n",
    "train_node_idx = torch.where(train_mask == 1)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8ff4b0c6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "' Train Logistic Regression '"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "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_test = enc.transform(test_y.reshape(-1, 1)).toarray()\n",
    "\"\"\" Train Logistic Regression \"\"\"\n",
    "# lr = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "# lr.fit(train_x, train_y, sample_weight=None, verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7c3e39c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_remove_index_train_all(from_indexes, to_indexes, train_mask, seed_val=10):\n",
    "    torch.manual_seed(seed_val)\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",
    "\n",
    "        to_index_list = torch.where(from_indexes == f_index)[0]\n",
    "        \n",
    "#         print(f_index)\n",
    "#         random_index = torch.randint(0, len(to_index_list), (1,))[0]\n",
    "        for to_index_e in to_index_list:\n",
    "#             print(to_index_list)\n",
    "#             print(to_index_e.item())\n",
    "#             j = to_index_list[to_index_e[0]]\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": 11,
   "id": "6681b194",
   "metadata": {},
   "outputs": [],
   "source": [
    "from_indexes, to_indexes = graph.edges()\n",
    "# f_l, t_l = generate_remove_index_train_all(from_indexes, to_indexes, train_mask)\n",
    "f_l, t_l = from_indexes, to_indexes\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "46fd48e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "changed_list = []\n",
    "changed_list_change = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "211480df",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # convert to one-hot labels\n",
    "# enc = OneHotEncoder(handle_unknown='ignore')\n",
    "# enc.fit(train_y.reshape(-1, 1))\n",
    "# one_hot_labels_train_orig = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "# one_hot_labels_val = enc.transform(val_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "# # train the original data\n",
    "# # calculate the hessian matrix\n",
    "# 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",
    "\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": 14,
   "id": "68e1eda0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fit model\n",
      "calculate loss\n",
      "calculate gradient\n",
      "start hess\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  4%|█▎                                 | 5783/153430 [04:34<1:56:57, 21.04it/s]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_9701/1162735254.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     27\u001b[0m \u001b[0;31m#                                                                     one_hot_labels_test, l2_reg = True)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     28\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'start hess'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 29\u001b[0;31m \u001b[0mhess\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlr_origin\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhess_cuda\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtrain_x\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlogits_train_y_origin\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ml2_reg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\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     30\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     31\u001b[0m \u001b[0mloss_grad_hvp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfast_get_inv_hvp_cuda\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mhess\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mval_loss_total_grad_orig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcholskey\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/Desktop/Projects/Project6_influence_function/graph_influence_function/experiments/../model_softmax.py\u001b[0m in \u001b[0;36mhess_cuda\u001b[0;34m(self, x, logits, sample_weight, l2_reg, fit_intercept)\u001b[0m\n\u001b[1;32m    242\u001b[0m             \u001b[0mtemp_x\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    243\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 244\u001b[0;31m             \u001b[0mtemp_factor\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiag\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtemp_pred\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mcp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meinsum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'i, j -> ij'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtemp_pred\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtemp_pred\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    245\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    246\u001b[0m             \u001b[0mtemp_indiv_hessian\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0meinsum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'ij, k, l -> ikjl'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtemp_factor\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtemp_x\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtemp_x\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreshape\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mKD\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mKD\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/cupy/_creation/matrix.py\u001b[0m in \u001b[0;36mdiag\u001b[0;34m(v, k)\u001b[0m\n\u001b[1;32m     37\u001b[0m         \u001b[0msize\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mabs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     38\u001b[0m         \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcupy\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzeros\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msize\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 39\u001b[0;31m         \u001b[0mret\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdiagonal\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\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[0mv\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     40\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mret\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     41\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "# convert to one-hot labels\n",
    "enc = OneHotEncoder(handle_unknown='ignore')\n",
    "enc.fit(train_y.reshape(-1, 1))\n",
    "one_hot_labels_train_orig = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "one_hot_labels_test = enc.transform(test_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "# train the original data\n",
    "# calculate the hessian matrix\n",
    "lr_origin = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "\n",
    "print('fit model')\n",
    "lr_origin.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "\n",
    "logits_test_y_origin = test_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",
    "print('calculate loss')\n",
    "ori_val_loss, ave_ori_val_loss = lr_origin.log_loss(logits_test_y_origin, one_hot_labels_test, l2_reg=True)\n",
    "\n",
    "# numpy_theoritic_loss = log_loss(test_y, softmax(logits_test_y_origin, axis=1))\n",
    "\n",
    "# assert np.allclose(numpy_theoritic_loss, ave_ori_val_loss)\n",
    "print('calculate gradient')\n",
    "# val_loss_total_grad_orig, val_loss_indiv_grad_orig = lr_origin.grad(test_x, \n",
    "#                                                                     logits_test_y_origin,\n",
    "#                                                                     one_hot_labels_test, l2_reg = True)\n",
    "print('start hess')\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": 13,
   "id": "f0200864",
   "metadata": {},
   "outputs": [],
   "source": [
    "# acctual_influence_1 = []\n",
    "# predict_influence_1 = []\n",
    "\n",
    "# for k in tqdm(range(len(f_l))):\n",
    "#     eis = EdgeInfluenceSGC(graph=graph, feature=feat, from_index=f_l[k], to_index=t_l[k])\n",
    "#     eis.remove_edges_sgc_from_influence()\n",
    "#     feat_removed1 = eis.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",
    "#     if extra_index_train == []:\n",
    "#         predict_influence_1.append(0.0)\n",
    "#         acctual_influence_1.append(0.0)\n",
    "#         continue\n",
    "    \n",
    "#     feat_to_be_added = feat_removed1[extra_index_train].numpy()\n",
    "#     perturb_index = extra_index_train_in_train\n",
    "    \n",
    "    \n",
    "#     train_x_new = feat_to_be_added\n",
    "#     train_y_new = train_y[perturb_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",
    "#     pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "# #     weight_orig = np.ones(len(train_x_orig)) # 1...1...11\n",
    "    \n",
    "# #     weight_1 = np.ones(len(train_x_orig))\n",
    "# #     weight_1[len(train_x_orig) - len(perturb_index):] = 0 # 1...1...10\n",
    "    \n",
    "# #     weight_2 = np.ones(len(train_x_orig))\n",
    "# #     weight_2[len(train_x_orig) - len(perturb_index):] = 0 \n",
    "# #     weight_2[perturb_index] = 0 # 1...0...10\n",
    "    \n",
    "#     weight_3 = np.ones(len(train_x_orig))\n",
    "#     weight_3[perturb_index] = 0 # 1...0...11\n",
    "    \n",
    "# #     lr_new_1 = SimplifiedGraphNeuralNetwork(l2_reg=1.0, fit_intercept=True)\n",
    "# #     train_x_delete_1 = train_x_orig[weight_1 == 1]\n",
    "# #     train_y_delete_1 = train_y_orig[weight_1 == 1]\n",
    "    \n",
    "# #     assert(np.allclose(train_x_delete_1, train_x))\n",
    "# #     assert(np.allclose(train_y_delete_1, train_y))\n",
    "    \n",
    "# #     lr_new_1.fit(train_x_delete_1, train_y_delete_1)\n",
    "# #     logits_val_y_new_1 = val_x @ lr_new_1.model.coef_.T + lr_new_1.model.intercept_\n",
    "# #     new_ori_val_loss_1, _ = lr_new_1.log_loss(logits_val_y_new_1, one_hot_labels_val)\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",
    "#     lr_new_2.fit(train_x_delete_2, train_y_delete_2)\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": 14,
   "id": "ff3b22ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████| 108365/108365 [2:16:29<00:00, 13.23it/s]\n"
     ]
    }
   ],
   "source": [
    "acctual_influence_1 = []\n",
    "predict_influence_1 = []\n",
    "\n",
    "for k in tqdm(range(len(f_l))):\n",
    "\n",
    "    eis = EdgeInfluenceSGC(graph=graph, feature=feat, from_index=f_l[k], to_index=t_l[k])\n",
    "    eis.remove_edges_sgc_from_influence()\n",
    "    feat_removed1 = eis.calculate_modified_features()\n",
    "    \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",
    "    if extra_index_train != []:\n",
    "        predict_influence_1.append(0.0)\n",
    "        acctual_influence_1.append(0.0)\n",
    "        continue\n",
    "    \n",
    "    feat_to_be_added = feat_removed1[extra_index_train].numpy()\n",
    "    perturb_index = extra_index_train_in_train\n",
    "    \n",
    "    \n",
    "    train_x_new = feat_to_be_added\n",
    "    train_y_new = train_y[perturb_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",
    "    pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "    \n",
    "    \n",
    "    weight_3 = np.ones(len(train_x_orig))\n",
    "    weight_3[perturb_index] = 0 # 1...0...11\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",
    "    lr_new_2.fit(train_x_delete_2, train_y_delete_2)\n",
    "    logits_test_y_new_2 = test_x @ lr_new_2.model.coef_.T + lr_new_2.model.intercept_\n",
    "    new_ori_val_loss_2, _ = lr_new_2.log_loss(logits_test_y_new_2, one_hot_labels_test, 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": 15,
   "id": "34d7be17",
   "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"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of edges in consider 108365\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "low_limit = -10\n",
    "up_limit = 10\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 10, color='blue')\n",
    "plt.xlabel('actual change in loss')\n",
    "plt.ylabel('predicted change in loss')\n",
    "# plt.title('Influence function on edges of Cora dataset perturb edges:' + str(batch_edges))\n",
    "# plt.title('Influence function on Complete Node of Citeseer dataset')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(low_limit, up_limit)\n",
    "# plt.title('Influence function on Iris dataset')\n",
    "plt.show()\n",
    "print('Number of edges in consider %d'% len(f_l))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a9668927",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([], dtype=float32)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "extra_index_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "ba4a265b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.03779802,  0.03779802,  0.03779802, ..., -0.00048981,\n",
       "        0.00595342, -0.02626843])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(acctual_influence_1)[np.array(acctual_influence_1) !=0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "5fa30ffb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=0.2634897498570285, pvalue=0.0)"
      ]
     },
     "execution_count": 18,
     "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": 19,
   "id": "1fe359e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=0.11385098593330309, pvalue=2.12555089769619e-309)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(acctual_influence_1, predict_influence_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "429ed2c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame([acctual_influence_1, predict_influence_1, f_l.numpy().astype(int), t_l.numpy().astype(int)]).T\n",
    "df.columns = ['acctual_influence', 'predict_influence', 'from_edges', 'to_edges']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "ebc16808",
   "metadata": {},
   "outputs": [],
   "source": [
    "df.to_csv('edge_influence_train_on_test/' + data_set + '_edge_influence_001.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "eac40fdb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "df = pd.read_csv('edge_influence_train_on_test/'+ data_set + '_edge_influence_001.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "6e1af69d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f3730dea970>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "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",
    "import numpy as np\n",
    "low_limit = -10\n",
    "up_limit = 10\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.scatter(df['acctual_influence'], df['predict_influence'], s = 10, color='blue')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "b446fd25",
   "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>acctual_influence</th>\n",
       "      <th>predict_influence</th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.0</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>18.0</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.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>108360</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19712.0</td>\n",
       "      <td>19712.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108361</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19713.0</td>\n",
       "      <td>19713.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108362</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19714.0</td>\n",
       "      <td>19714.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108363</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19715.0</td>\n",
       "      <td>19715.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108364</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19716.0</td>\n",
       "      <td>19716.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>108365 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        acctual_influence  predict_influence  from_edges  to_edges\n",
       "0                     0.0                0.0         1.0       0.0\n",
       "1                     0.0                0.0         0.0       1.0\n",
       "2                     0.0                0.0        12.0       1.0\n",
       "3                     0.0                0.0        18.0       2.0\n",
       "4                     0.0                0.0         3.0       2.0\n",
       "...                   ...                ...         ...       ...\n",
       "108360                0.0                0.0     19712.0   19712.0\n",
       "108361                0.0                0.0     19713.0   19713.0\n",
       "108362                0.0                0.0     19714.0   19714.0\n",
       "108363                0.0                0.0     19715.0   19715.0\n",
       "108364                0.0                0.0     19716.0   19716.0\n",
       "\n",
       "[108365 rows x 4 columns]"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "57ab6798",
   "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>acctual_influence</td>\n",
       "      <td>predict_influence</td>\n",
       "      <td>from_edges</td>\n",
       "      <td>to_edges</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>12.0</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>18.0</td>\n",
       "      <td>2.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>108361</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19712.0</td>\n",
       "      <td>19712.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108362</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19713.0</td>\n",
       "      <td>19713.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108363</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19714.0</td>\n",
       "      <td>19714.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108364</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19715.0</td>\n",
       "      <td>19715.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>108365</th>\n",
       "      <td>0.0</td>\n",
       "      <td>0.0</td>\n",
       "      <td>19716.0</td>\n",
       "      <td>19716.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>108366 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                        0                  1           2         3\n",
       "0       acctual_influence  predict_influence  from_edges  to_edges\n",
       "1                     0.0                0.0         1.0       0.0\n",
       "2                     0.0                0.0         0.0       1.0\n",
       "3                     0.0                0.0        12.0       1.0\n",
       "4                     0.0                0.0        18.0       2.0\n",
       "...                   ...                ...         ...       ...\n",
       "108361                0.0                0.0     19712.0   19712.0\n",
       "108362                0.0                0.0     19713.0   19713.0\n",
       "108363                0.0                0.0     19714.0   19714.0\n",
       "108364                0.0                0.0     19715.0   19715.0\n",
       "108365                0.0                0.0     19716.0   19716.0\n",
       "\n",
       "[108366 rows x 4 columns]"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pd.read_csv('edge_influence_train_on_test/'+ data_set + '_edge_influence_001.csv', header = None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "67acbb69",
   "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
}
