{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9b1d4ab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy_ml\n",
    "import tensorflow.compat.v1 as tf\n",
    "import dgl\n",
    "import scipy\n",
    "\n",
    "from dgl import function as fn\n",
    "from generate_mid_layer_feature import FeatureExtraction\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 sklearn.preprocessing import LabelBinarizer\n",
    "from sklearn.utils import check_array\n",
    "from dataset import load_graph_dataset\n",
    "from scipy.linalg import cho_solve, cho_factor\n",
    "from model_node_influence import NodeInfluenceSGC\n",
    "\n",
    "from sklearn.datasets import load_iris\n",
    "from sklearn.model_selection import train_test_split\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork\n",
    "from scipy.special import softmax, log_softmax\n",
    "from matplotlib import pyplot as plt\n",
    "import warnings\n",
    "\n",
    "from sklearnex import patch_sklearn, config_context\n",
    "patch_sklearn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cfaff685",
   "metadata": {},
   "outputs": [],
   "source": [
    "warnings.filterwarnings(\"ignore\", category=DeprecationWarning)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1984291f",
   "metadata": {},
   "source": [
    "##### 1, Removing a node feature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c63ffcaa",
   "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": "cfe8be6c",
   "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",
      "accuracy: 0.793\n"
     ]
    }
   ],
   "source": [
    "from generate_mid_layer_feature import FeatureExtraction\n",
    "\n",
    "FeatureExtractor = FeatureExtraction(num_layers=2, num_iter=100, lr=0.02, hidden_feat=20, device='cpu',\n",
    "                                         dataset='cora')\n",
    "FeatureExtractor.extract_feature()\n",
    "train_x, train_y, val_x, val_y, test_x, test_y = FeatureExtractor.preprocessed_data(save='feat.csv')\n",
    "\n",
    "\n",
    "train_x = train_x.astype(np.float64)\n",
    "test_x = test_x.astype(np.float64)\n",
    "train_y = train_y.astype(np.float64)\n",
    "test_y = test_y.astype(np.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "773a5270",
   "metadata": {},
   "outputs": [],
   "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",
    "\n",
    "\"\"\" Train Logistic Regression \"\"\"\n",
    "lr = SimplifiedGraphNeuralNetwork(l2_reg=1.0, fit_intercept=True)\n",
    "lr.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "logits_test_y = test_x @ lr.model.coef_.T + lr.model.intercept_\n",
    "logits_train_y = train_x @ lr.model.coef_.T + lr.model.intercept_\n",
    "\n",
    "ori_val_loss, ave_ori_val_loss = lr.log_loss(logits_test_y, one_hot_labels_test)\n",
    "\n",
    "numpy_theoritic_loss = log_loss(test_y, softmax(logits_test_y, axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "713a4c63",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2022-04-14 17:46:54.722181: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:939] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
      "2022-04-14 17:46:54.722765: I tensorflow/stream_executor/cuda/cuda_gpu_executor.cc:939] successful NUMA node read from SysFS had negative value (-1), but there must be at least one NUMA node, so returning NUMA node zero\n",
      "2022-04-14 17:46:54.724879: W tensorflow/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libcudnn.so.8'; dlerror: libcudnn.so.8: cannot open shared object file: No such file or directory\n",
      "2022-04-14 17:46:54.724892: W tensorflow/core/common_runtime/gpu/gpu_device.cc:1850] Cannot dlopen some GPU libraries. Please make sure the missing libraries mentioned above are installed properly if you would like to use GPU. Follow the guide at https://www.tensorflow.org/install/gpu for how to download and setup the required libraries for your platform.\n",
      "Skipping registering GPU devices...\n",
      "2022-04-14 17:46:54.725121: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "train_total_grad, train_indiv_grad = lr.grad(train_x, logits_train_y, one_hot_labels_train)\n",
    "val_loss_total_grad, val_loss_indiv_grad = lr.grad(test_x, logits_test_y, one_hot_labels_test)\n",
    "\n",
    "hessian_no_reg, hess, hessian_reg_term = lr.hess(train_x, logits_train_y)\n",
    "\n",
    "loss_grad_hvp = lr.get_inv_hvp(hess, val_loss_total_grad.T)\n",
    "\n",
    "pred_infl = train_indiv_grad.dot(loss_grad_hvp)\n",
    "\n",
    "pred_infl = list(pred_infl.reshape(-1))\n",
    "#\n",
    "num_train = len(train_x)\n",
    "act_infl = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5e84e4a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(num_train):\n",
    "    lr_new = SimplifiedGraphNeuralNetwork(l2_reg=1.0, fit_intercept=True)\n",
    "    train_x_new = np.delete(train_x, i, axis = 0)\n",
    "    train_y_new = np.delete(train_y, i)\n",
    "    lr_new.fit(train_x_new, train_y_new)\n",
    "    \n",
    "    logits_test_y_new = test_x @ lr_new.model.coef_.T + lr_new.model.intercept_\n",
    "    \n",
    "    \n",
    "    new_ori_val_loss, new_ave_ori_val_loss = lr_new.log_loss(logits_test_y_new, one_hot_labels_test)\n",
    "    act_infl.append(new_ori_val_loss - ori_val_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "dc038d2a",
   "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",
    "x = np.linspace(-6, 20)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.plot(act_infl, pred_infl, 'o', color='blue')\n",
    "plt.xlabel('actual change in loss')\n",
    "plt.ylabel('predicted change in loss')\n",
    "# plt.title('Influence function on Cora dataset')\n",
    "plt.title('Influence function on Iris dataset')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4406540d",
   "metadata": {},
   "outputs": [],
   "source": [
    "actual_influence_node_features = act_infl\n",
    "predict_influence_node_features = pred_infl"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4cf1edf",
   "metadata": {},
   "source": [
    "##### Removing the corresponding features influenced by that node"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "279c1ebc",
   "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('cora')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "cfdd0a31",
   "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",
      "accuracy: 0.793\n"
     ]
    }
   ],
   "source": [
    "FeatureExtractor = FeatureExtraction(num_layers=2, num_iter=100, lr=0.02, hidden_feat=20, device='cpu',\n",
    "                                         dataset='cora')\n",
    "FeatureExtractor.extract_feature()\n",
    "train_x, train_y, val_x, val_y, test_x, test_y = FeatureExtractor.preprocessed_data(save='feat.csv')\n",
    "\n",
    "train_x = train_x.astype(np.float64)\n",
    "test_x = test_x.astype(np.float64)\n",
    "train_y = train_y.astype(np.float64)\n",
    "test_y = test_y.astype(np.float64)\n",
    "\n",
    "\n",
    "feat1, feat2 = FeatureExtractor.model.get_embed()\n",
    "\n",
    "w1, w2 = FeatureExtractor.model.get_weight()\n",
    "\n",
    "feat2_calculated = feat1 @ w1.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "98f8f753",
   "metadata": {},
   "outputs": [],
   "source": [
    "from_indexes, to_indexes = graph.edges()\n",
    "\n",
    "acctual_influence_1 = []\n",
    "acctual_influence_2 = []\n",
    "\n",
    "predict_influence_1 = []\n",
    "predict_influence_2 = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b70ffa94",
   "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(2):\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": 14,
   "id": "25b409bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0, 1] 0\n",
      "[0, 1] 1\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[2] 2\n",
      "[3] 3\n",
      "[4] 4\n",
      "[5, 6, 7, 8, 9] 5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[5, 6, 7, 8, 9] 6\n",
      "[5, 6, 7, 8, 9] 7\n",
      "[5, 6, 7, 8, 9] 8\n",
      "[5, 6, 7, 8, 9] 9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[10] 10\n",
      "[11] 11\n",
      "[12] 12\n",
      "[13, 14] 13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[13, 14] 14\n",
      "[15] 15\n",
      "[16] 16\n",
      "[17] 17\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[18] 18\n",
      "[19, 21] 19\n",
      "[20] 20\n",
      "[19, 21, 25] 21\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[22, 65] 22\n",
      "[23, 38, 104] 23\n",
      "[24, 41, 54] 24\n",
      "[21, 25, 42, 43] 25\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[26, 76, 80, 82] 26\n",
      "[27, 49] 27\n",
      "[28] 28\n",
      "[29] 29\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[30, 76] 30\n",
      "[31, 47] 31\n",
      "[32] 32\n",
      "[33, 56, 66, 114] 33\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[34] 34\n",
      "[35, 39, 106, 107] 35\n",
      "[36, 65] 36\n",
      "[37] 37\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[23, 38, 64, 104, 120] 38\n",
      "[35, 39, 59, 106] 39\n",
      "[40] 40\n",
      "[24, 41, 54, 104] 41\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[25, 42, 43, 71, 104, 114] 42\n",
      "[25, 42, 43, 71, 104, 114] 43\n",
      "[44] 44\n",
      "[45] 45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[46, 54, 97, 114, 120] 46\n",
      "[31, 47, 58, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 47\n",
      "[48, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 130] 48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[27, 49, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 49\n",
      "[50, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 50\n",
      "[51, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 51\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[52, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 52\n",
      "[53, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 53\n",
      "[24, 41, 46, 54, 104] 54\n",
      "[55, 84, 97, 99, 114] 55\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33, 56, 66, 84, 97, 99, 114] 56\n",
      "[57, 60, 72, 73, 74, 84, 97, 99, 100, 101, 114] 57\n",
      "[47, 58, 76, 77, 78, 79, 80, 81, 82, 83, 89, 130] 58\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[39, 59, 106, 107, 120] 59\n",
      "[57, 60] 60\n",
      "[61, 91, 135] 61\n",
      "[62, 94, 120, 125] 62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[63, 128] 63\n",
      "[38, 64, 68] 64\n",
      "[22, 36, 49, 65, 70, 71, 72, 73, 74, 76, 77, 78, 79, 80, 81, 82, 83, 84, 89, 99, 100, 101, 114, 130] 65\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33, 56, 66, 72, 73, 74, 84, 97, 99, 100, 101, 114] 66\n",
      "[67, 89, 90, 91, 106, 107, 135] 67\n",
      "[64, 68, 103, 125, 128] 68\n",
      "[69, 107, 125] 69\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[65, 70, 72, 73, 74, 84, 100, 101, 104, 114, 120] 70\n",
      "[42, 43, 65, 71, 72, 73, 74, 84, 97, 99, 100, 101, 110, 114] 71\n",
      "[57, 65, 66, 70, 71, 72, 73, 74, 84, 97, 99, 100, 101, 104, 112, 114] 72\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[57, 65, 66, 70, 71, 72, 73, 74, 84, 97, 99, 100, 101, 104, 112, 114] 73\n",
      "[57, 65, 66, 70, 71, 72, 73, 74, 84, 97, 99, 100, 101, 104, 112, 114] 74\n",
      "[75, 99, 100, 101, 114] 75\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[26, 30, 47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 76\n",
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 77\n",
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 78\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 79\n",
      "[26, 47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 80\n",
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 113, 114, 120, 130] 81\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[26, 47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 82\n",
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 114, 120, 130] 83\n",
      "[55, 56, 57, 65, 66, 70, 71, 72, 73, 74, 84, 97, 99, 100, 101, 104, 112, 114] 84\n",
      "[85, 86, 90, 94, 104, 120, 121, 125] 85\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[85, 86, 90, 94, 104, 120, 121, 125] 86\n",
      "[87, 95, 114, 117, 127, 129] 87\n",
      "[88] 88\n",
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 67, 76, 77, 78, 79, 80, 81, 82, 83, 89, 90, 91, 106, 114, 120, 128, 130, 135] 89\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[67, 85, 86, 89, 90, 91, 106, 107, 120, 125, 128, 135] 90\n",
      "[61, 67, 89, 90, 91, 106, 107, 128, 135] 91\n",
      "[92, 110, 115, 116, 117] 92\n",
      "[93, 102, 116] 93\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[62, 85, 86, 94, 107, 120, 125] 94\n",
      "[87, 95, 96, 111, 114, 115, 116, 117, 121, 123, 126, 129] 95\n",
      "[95, 96, 121, 126, 127] 96\n",
      "[46, 55, 56, 57, 66, 71, 72, 73, 74, 84, 97, 99, 100, 101, 104, 114, 115, 116, 117, 126, 127] 97\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[98, 126, 127] 98\n",
      "[55, 56, 57, 65, 66, 71, 72, 73, 74, 75, 84, 97, 99, 100, 101, 104, 114, 128, 135] 99\n",
      "[57, 65, 66, 70, 71, 72, 73, 74, 75, 84, 97, 99, 100, 101, 104, 107, 112, 114, 128] 100\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[57, 65, 66, 70, 71, 72, 73, 74, 75, 84, 97, 99, 100, 101, 104, 112, 114, 128] 101\n",
      "[93, 102, 104, 120, 128] 102\n",
      "[68, 103, 104, 128] 103\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[23, 38, 41, 42, 43, 54, 70, 72, 73, 74, 84, 85, 86, 97, 99, 100, 101, 102, 103, 104, 105, 106, 114, 120, 128] 104\n",
      "[104, 105, 120, 128] 105\n",
      "[35, 39, 59, 67, 89, 90, 91, 104, 106, 107, 120, 125, 128, 135] 106\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[35, 59, 67, 69, 90, 91, 94, 100, 106, 107, 125, 128, 135] 107\n",
      "[108, 128] 108\n",
      "[109, 118, 119] 109\n",
      "[71, 92, 110, 116, 123, 129, 130, 131, 134] 110\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[95, 111, 117, 129, 130, 131, 134] 111\n",
      "[72, 73, 74, 84, 100, 101, 112, 114, 129, 130, 131, 134] 112\n",
      "[81, 113, 129, 130, 131, 134] 113\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[33, 42, 43, 46, 48, 55, 56, 57, 65, 66, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 87, 89, 95, 97, 99, 100, 101, 104, 112, 114, 126, 127, 128, 129, 130, 131, 132, 133, 134, 135] 114\n",
      "[92, 95, 97, 115, 116, 117, 120, 125, 126, 127, 134] 115\n",
      "[92, 93, 95, 97, 110, 115, 116, 117, 120, 123, 125, 135] 116\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[87, 92, 95, 97, 111, 115, 116, 117, 120, 125, 129] 117\n",
      "[109, 118, 119, 123, 134, 136] 118\n",
      "[109, 118, 119, 123, 126, 127, 134, 136] 119\n",
      "[38, 46, 59, 62, 70, 76, 77, 78, 79, 80, 81, 82, 83, 85, 86, 89, 90, 94, 102, 104, 105, 106, 115, 116, 117, 120, 121, 125, 128, 129, 130, 131, 134, 136] 120\n",
      "[85, 86, 95, 96, 120, 121, 125, 126, 134, 136] 121\n",
      "[122, 134, 136] 122\n",
      "[95, 110, 116, 118, 119, 123, 134, 136] 123\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[124, 132, 133] 124\n",
      "[62, 68, 69, 85, 86, 90, 94, 106, 107, 115, 116, 117, 120, 121, 125, 128] 125\n",
      "[95, 96, 97, 98, 114, 115, 119, 121, 126, 127, 129, 130, 131, 134] 126\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[87, 96, 97, 98, 114, 115, 119, 126, 127] 127\n",
      "[63, 68, 89, 90, 91, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 114, 120, 125, 128, 135] 128\n",
      "[87, 95, 110, 111, 112, 113, 114, 117, 120, 126, 129, 130, 131, 134] 129\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[47, 48, 49, 50, 51, 52, 53, 58, 65, 76, 77, 78, 79, 80, 81, 82, 83, 89, 110, 111, 112, 113, 114, 120, 126, 129, 130, 131, 134] 130\n",
      "[110, 111, 112, 113, 114, 120, 126, 129, 130, 131, 134] 131\n",
      "[114, 124, 132, 133, 137] 132\n",
      "[114, 124, 132, 133, 137] 133\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[110, 111, 112, 113, 114, 115, 118, 119, 120, 121, 122, 123, 126, 129, 130, 131, 134, 136] 134\n",
      "[61, 67, 89, 90, 91, 99, 106, 107, 114, 116, 128, 135, 136] 135\n",
      "[118, 119, 120, 121, 122, 123, 134, 135, 136, 137, 139] 136\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[132, 133, 136, 137, 138, 139] 137\n",
      "[137, 138, 139] 138\n",
      "[136, 137, 138, 139] 139\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n",
      "/home/zizhang/anaconda3/lib/python3.8/site-packages/dgl/base.py:45: DGLWarning: DGLGraph.edge_id is deprecated. Please use DGLGraph.edge_ids.\n",
      "  return warnings.warn(message, category=category, stacklevel=1)\n"
     ]
    }
   ],
   "source": [
    "train_node_idx = torch.where(train_mask == 1)[0]\n",
    "for n in range(len(train_node_idx)):\n",
    "    \n",
    "    node_id = train_node_idx.numpy()[n]\n",
    "    nis = NodeInfluenceSGC(graph = graph, feature=feat, node_index=node_id)\n",
    "    nis.remove_edges_sgc()\n",
    "    feat_removed1 = nis.calculate_modified_features()\n",
    "    extra_index = torch.unique(torch.where(feat0 != feat_removed1)[0])\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",
    "    train_node_idx_in_train = np.where(extra_index_train == node_id)[0][0]\n",
    "    assert(n in extra_index_train_in_train)\n",
    "    print(extra_index_train_in_train, n)\n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    \n",
    "    feat_to_be_added = feat_removed1[extra_index_train_in_train].numpy()\n",
    "    feat_to_be_added_2 = feat_to_be_added @ w1.T\n",
    "    perturb_index = extra_index_train_in_train\n",
    "    \n",
    "    \n",
    "    train_x_new = feat_to_be_added_2\n",
    "    train_y_new = train_y[perturb_index]\n",
    "    train_x_orig = np.concatenate([train_x, train_x_new])\n",
    "    train_y_orig = np.concatenate([train_y, train_y_new])\n",
    "\n",
    "    enc = OneHotEncoder(handle_unknown='ignore')\n",
    "    enc.fit(train_y_orig.reshape(-1, 1))\n",
    "    one_hot_labels_train_orig = enc.transform(train_y_orig.reshape(-1, 1)).toarray()\n",
    "    one_hot_labels_test = enc.transform(test_y.reshape(-1, 1)).toarray()\n",
    "\n",
    "    weight_orig = np.ones(len(train_x_orig))\n",
    "    weight_1 = np.ones(len(train_x_orig))\n",
    "    weight_1[len(train_x_orig) - len(perturb_index):] = 0 # newly perturbed index set to 0\n",
    "    weight_2 = np.ones(len(train_x_orig))\n",
    "    weight_2[perturb_index] = 0 # perturbed index set to 0\n",
    "    # assert (np.allclose(train_x_orig[weight_1 == 1], train_x))\n",
    "\n",
    "\n",
    "    lr_origin = SimplifiedGraphNeuralNetwork(l2_reg=1.0, fit_intercept=True)\n",
    "    lr_origin.fit(train_x_orig, train_y_orig, sample_weight=None, verbose=False)\n",
    "    logits_test_y_origin = test_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "    logits_train_y_origin = train_x_orig @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    ori_val_loss, ave_ori_val_loss = lr_origin.log_loss(logits_test_y_origin, one_hot_labels_test)\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",
    "\n",
    "    train_total_grad_orig, train_indiv_grad_orig = lr_origin.grad(train_x_orig, \n",
    "                                                    logits_train_y_origin, \n",
    "                                                    one_hot_labels_train_orig)\n",
    "\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)\n",
    "\n",
    "    hessian_no_reg, hess, hessian_reg_term = lr_origin.hess(train_x_orig, logits_train_y_origin)\n",
    "\n",
    "\n",
    "    loss_grad_hvp = lr_origin.get_inv_hvp(hess, val_loss_total_grad_orig, cho = False, use_eps = True)\n",
    "#     loss_grad_hvp = lr_origin.get_inv_hvp(hess, val_loss_total_grad_orig.T, cho = False, use_eps = False)\n",
    "\n",
    "\n",
    "    pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "\n",
    "    # delete \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_test_y_new_1 = test_x @ lr_new_1.model.coef_.T + lr_new_1.model.intercept_\n",
    "    new_ori_val_loss_1, _ = lr_new_1.log_loss(logits_test_y_new_1, one_hot_labels_test)\n",
    "    \n",
    "    acctual_influence_1.append(new_ori_val_loss_1 - ori_val_loss)\n",
    "    predict_influence_1.append(np.sum(pred_infl[140:]))\n",
    "    \n",
    "    \n",
    "    lr_new_2 = SimplifiedGraphNeuralNetwork(l2_reg=1.0, fit_intercept=True)\n",
    "    train_x_delete_2 = train_x_orig[weight_2 == 1]\n",
    "    train_y_delete_2 = train_y_orig[weight_2 == 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)\n",
    "    \n",
    "    acctual_influence_2.append(new_ori_val_loss_2 - ori_val_loss)\n",
    "    predict_influence_2.append(np.sum(pred_infl[perturb_index]))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e825e849",
   "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",
    "x = np.linspace(-300, 200)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.plot(acctual_influence_1, predict_influence_1, 'o', 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')\n",
    "plt.ylim(-300, 200)\n",
    "plt.xlim(-300, 200)\n",
    "# plt.title('Influence function on Iris dataset')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b509f4bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAEWCAYAAACqitpwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAA5gUlEQVR4nO3dd3xUZfb48c+hE3rvvVcLodmWVVTsYtnVZe0r1q9tfwouFiwollXX3VXEBipWiqBiwwK6FgSFJHQIofcaEkg9vz+eGx3iTDIJ03Per9e8ZubemXvPM+3Mc597zxVVxRhjjAmlStEOwBhjTOKx5GKMMSbkLLkYY4wJOUsuxhhjQs6SizHGmJCz5GKMMSbkLLnEMBFpJiLzRCRTRP4pImNF5I1oxxWs4vFHeN0HRKRjJNcZTiJypYh8G+04iojzqojsEZH50Y6nNCLSXkRURKpEO5aKwpJLhIlIhogMDfLhI4GdQF1V/XsYwwqXiMQvIl+LyN98p6lqbVVND9c6j5TPj92BYpc/Rzu2IJ0AnAq0VtUB/h4gIi1E5GUR2eL9wVguIg+ISK3Ihlo2IjJERDYmynqixZJLbGsHLNX4PdI13uOPhPpeIiy6vBPtgILUDshQ1Sx/M0WkIfA9UBMYrKp1cMmoPtCpLCvyekn2WxVvVNUuEbwAGcBQ7/aVwLfAk8AeYC1whjdvEpAH5AIHgKHAWOANb/4QYGMJy64EjAbWALuAd4GG3rz2gAJXAOtxvYsxPsupDPzDe24msBBo483rDnwO7AZWAH8K0E5/8U8CHvZ5zGFt8OL/f0AKsA94B6jhM/88YBGw34ttGDAOKAAOeev5j/dYBTp7t+sBrwE7gHXAPUCl0t6DAO3qAXwN7AWWAOcWa/N/gY+81+1HoFOA5RS9B1UCzG8EzPLaOh94CPjWZ/5p3uu/D3gOmAv8zWf+1cAyr02fAu286QI8DWz3npsC9A4QQ0svht3AauBab/o13utd4L3mD/h57sNAatHrHGD5xwE/eXH8BBznM+9r7739H3AQ6Axc5bUpE0gHrith2ZW993Sn99ibfF/vQMsCannrK/TadsB7HQbgkuVeYAvwH6Baaa8pUN2LYz2wDZiAS7h+1xPt36eQ/tZFO4CKduH3ySUPuNb7MtwAbAbEmz+Jw3+MxxJ8crkN+AFo7X3AXwDe8ua1975oL3of9KOAHKCHN/9O74ehm/fFOQr3Y1cL2OB9MasAx3pf3l4B2lo8/uL3D2uDF/9878vc0PvyX+/NG+B9cU/FJc5WQHdv3tf4/LB603yTy2vATKCO1/aVwDXBvAfFllkV9yP7D6AacDLux6mbT/t2e7FWAaYAbwd4bYreg0DJ5W3cH4JaQG9gE15yARrjks4F3npu9drwN2/++V6cPbz59wDfefNOx/1ZqO+9tz2AFgFimItLXDWAo3HJ+RSf1+1bf8/z5v+An6TjM78hLvFd5sV4qXe/kc97uh7o5c2vCpyF6/UI8AcgGzg2wPKvB5YDbbx1fcXhySXgsvD/3eoHDPJiaY/7bN5W2msKPINL0A1xn78PgEcDrSeRLlEPoKJd+H1yWe0zL8n7AjT37k+i/MllWdEPgXe/Be4HqOjLobjt5UXz5wOXeLdXAOf5if3PwDfFpr0A3B+grcXjL37/sDZ48f/V5/7jwASf9TwdYD1fEyC54BJGDtDTZ951wNfBvAfFlnkisBWff+PAW8BYn/a95DPvTGB5gJiL3oO9xS49vJjz8JKn9/hH+C25XA587zNPcEm/KLl8jJc8vfuVcD+e7XAJcSXuh7KkXkUbXM+kjs+0R4FJPq9bScllFd4fgwDzLwPmF5v2PXClz3v6YCnfpfeBWwPM+9J3/bieXknJ/NdlFf9cBnj8bcAM77bf19R7X7Lw6b0Cg4G1wa4nni+2HTP6thbdUNVs72btECy3HTBDRPaKyF5csikAmvlbN+7Hp2i9bXCbnfwtc2DRMr3ljgCahyDe8sZUmsa4XsY6n2nrcD2f362zlPegJbBBVQuDWRaHxx8wPlWt73NZBjTB/QnYUGw9h8XhE7MCvgPD7YB/+bxHu3E/dK1U9UvcJp3/AttEZKKI1A3Q1t2qmllCW0uyC/eHJpCWxdrkb/m+7UdEzhCRH0Rkt9euM3Hvb6DlB3r9yrosRKSriHwoIltFZD8u2TcGKOE1bYL7s7LQ5734xJue8Cy5xK8s3AcXABGpzOEf2g24sQPfH64aqropiGVvwP+g6wZgbrFl1lbVG8oTM2VLSoFiAvePNJCduF5AO59pbXGbmcpqM9Cm2OByeZdVkh1APi6h+q6nyBbc5k7ADXj73se9VtcVe59qqup3AKr6rKr2w21y6orbDFrcZqChiNQpFkOwbZ0DDC9hIH4zh78n/pb/6/sqItWBabjxi2aqWh+YjUua/mwhwOsXxLL8fZ6ex21m66KqdXGbRn9dd4DXdCduXKWXz/tQT1WL/nCU9LmNe5Zc4tdKoIaInCUiVXHb1av7zJ8AjBORdgAi0kREzgty2S8BD4lIF29Pnb4i0gj4EOgqIpeJSFXv0l9EegS53EXAmSLSUESa4zYtBOtl4CoROUVEKolIKxHp7s3bBvg9pkVVC3BjF+NEpI73etwBlOd4oR9xCfIur+1DgHNw4yMh48U8HRgrIkki0hO380WRj4A+InK+d9zGTRyeqCcAd4tILwARqSciF3u3+4vIQO8zk8VvA/PFY9gAfAc8KiI1RKQvbiB/SpDNeAqoC0z2+Qy2EpGnvGXNxn2W/iIiVbxdsHviPmP+VMN9vncA+SJyBm5TVyDvAreISGsRaYDbuSXYZW0DGolIPZ9pdXDjXAe8z92vf6gCvaZeD/dF4GkRaerzGpxewnoShiWXOKWq+4AbcYlgE+5D7btp5F+4gcTPRCQTN8A6MMjFP4X7cn6G+0K9DNT0NpGcBlyC++e5FXiMw5NaSV4HFuPGVj7D7Q0WFFWdj9uR4GncwP5cfvvn+y/gInEH9D3r5+n/h3t90nF7hr0JvBLsun1iyAXOBc7A/St9DrhcVZeXdVk+9hY7zuUOb/rNuE1qW3FjOa/6xLETuBg3JrUL96O8ADe2hKrOwL0vb3ubcNK8mMH94L+IGzxf5z3/yQCxXYobG9oMzMCNrX0eTKNUdTdub7A84EfvM/gF7r1braq7gLOBv3sx3AWc7bXN3/IygVtwn8s9wF9wn+9AXsTtJbcY+BmXrINalvd+vgWke5uzWuL2YvwLbgeOFzn8s1vSazoKt3PFD957MQe3o0yg9SSMor2SjDFxytv0tBEYoapfRTseY8B6LsbEJRE5XUTqe+MHRdv/f4hyWMb8KqrJRUReEZHtIpLmM62hiHwuIqu86wY+8+4WkdUissJnu6UxFdFg3N5zO3HjPuer6sHohmTMb6K6WUxETsIdmfqaqvb2pj2O2wVyvIiMBhqo6ihvUPMt3AFqLXHbLrt6g5/GGGNiSFR7Lqo6D7cPvq/zgMne7cm4o42Lpr+tqjmquhY3SOa3YJ4xxpjoisXy081UdQuAqm4p2oUPd3CV7zbljQQ4oEtERuIq8lKrVq1+3bt39/cwY4wxPrJy8tm45yC5BYXkbl29U1XLfcBnLCaXQPwdLOV3m56qTgQmAiQnJ+uCBQvCGZcxxsS1zEN5jP94OVN+XM8xDZMYf0Efju/SpHgFhTKJxeSyTURaeL2WFrhKo+B6Kr5H3LbG7X9vjDGmnL5cvo0xM9LYtv8QfzuhA38/rRs1q1U+4uXG4q7Is/jtaOQrcNVsi6ZfIiLVRaQD0AVXbNEYY0wZ7c7K5ba3f+HqSQuoU6MK0244jnvO7hmSxAJR7rmIyFu4yqCNxZ2R7X5gPPCuiFyDK7l9MYCqLhGRd4GluLpLN9meYsYYUzaqygcpW3hg1hL2H8rjtqFduHFIZ6pVCW1fI6rJRVUvDTDrlACPH4c7gZAxxpgy2rrvEPe8n8acZds4qnU9HrtoIN2b+yuKfeRicczFGGNMCKkqb/+0gUc+WkZeYSH3nNWDq47vQOVKgYpKHzlLLsYYk8DW7cpi9LRUvk/fxeCOjRh/YR/aNaoV9vVacjHGmARUUKi8+r+1PPnZCqpWqsSjF/Thkv5tcKf/CT9LLsYYk2BWbM3krmkpLN6wl6E9mvLw+X1oXq9GRGOw5GKMMQkiN7+Q575ezX+/Wk2dGlV59tJjOKdvi4j1VnxZcjHGmASwaMNeRk1NYcW2TM49qiX3n9OTRrWDPY9f6FlyMcaYOHYwt4CnPl/By9+upWmdGrx8RTKn9GgW7bAsuRhjTLz6bs1ORk9LZf3ubP4ysC2jz+hO3RpVox0WYMnFGGPizv5DeTw6ezlvzV9Pu0ZJvHXtIAZ3ahTtsA5jycUYY+LInKXbGPN+Kjsycxh5UkduH9o1ZPXAQsmSizHGxIFdB3J44IOlzFq8me7N6zDxsmSOalM/2mEFZMnFGGNimKoya/Fmxs5awoGcfG4f2pUbhnQKeaHJULPkYowxMWrz3oPc834aXy7fztFt6vP4RX3p2qxOtMMKiiUXY4yJMYWFyls/refR2cspKFTuPbsnVx7XPqyFJkPNkosxxsSQtTuzGD0thR/X7ub4zo14dHhf2jZKinZYZWbJxRhjYkB+QSEvf7uWpz5fSbUqlXj8wr5cnNw6KqVbQsGSizHGRNmyLfsZNS2FlI37OLVnMx4+vzfN6ka20GSoWXIxxpgoyckv4L9frua5r9dQr2ZV/vOXYzirT3QKTYaaJRdjjImChev2MGpaCqu3H+CCY1px79k9aVCrWrTDChlLLsYYE0HZufk88ekKJn2XQYu6NXj1qv78sVvTaIcVcpZcjDEmQr5dtZPR01PYuOcglw1qx13DulEnRgpNhpolF2OMCbN9B/MY99FS3l2wkQ6Na/HOyEEM7BhbhSZDzZKLMcaE0adLtnLv+2nsysrlhiGduPWULtSoGnuFJkPNkosxxoTBjswcxs5awkepW+jRoi4vX9GfPq3rRTusiLHkYowxIaSqzPhlEw9+uJTsnALuPL0bI0/qSNXKsV1oMtQsuRhjTIhs2nuQMTNS+XrFDo5t6wpNdm4aH4UmQ82SizHGHKHCQmXKj+sY//FyFBh7Tk8uGxxfhSZDLWaTi4hkAJlAAZCvqski0hB4B2gPZAB/UtU90YrRGGPSdxxg9LRU5mfs5sQujXlkeB/aNIy/QpOhFrPJxfNHVd3pc3808IWqjheR0d79UdEJzRhTkeUXFDLxm3SembOKGlUq8cRFfbmoX/wWmgy1WE8uxZ0HDPFuTwa+xpKLMSbClmzex6hpKaRt2s+wXs158LxeNI3zQpOhFsvJRYHPRESBF1R1ItBMVbcAqOoWEUm8mgnGmJh1KK+Af3+5iglz02mQVI3nRxzLGX1aRDusmBTLyeV4Vd3sJZDPRWR5sE8UkZHASIC2bduGKz5jTAWyIGM3o6alsGZHFhf1a809Z/WgflLiFJoMtZhNLqq62bveLiIzgAHANhFp4fVaWgDbAzx3IjARIDk5WSMVszEm8WTluEKTk7/PoGW9mrx29QBO6tok2mHFvJhMLiJSC6ikqpne7dOAB4FZwBXAeO96ZvSiNMYkunkrd3D39FQ27zvIFYPbc+fp3ahVPSZ/NmNOrL5KzYAZ3l4XVYA3VfUTEfkJeFdErgHWAxdHMUZjTILam53Lwx8tY+rCjXRsUov3rhtMcvuG0Q4rrsRkclHVdOAoP9N3AadEPiJjTEXxceoW7p25hD3Zudz8x87cfHLnClFoMtRiMrkYY0ykbc88xP0zl/Bx2lZ6tazL5Kv706tlxSk0GWqWXIwxFZqqMnXhRh76cCmH8gsZNaw7157YgSoVrNBkqFlyMcZUWBt2Z/OPGal8s2on/ds3YPyFfenUpHa0w0oIllyMMRVOYaHy2vcZPP7pCgR46LxejBjYjkoVuNBkqFlyMcZUKKu3ZzJqWioL1+3hpK5NeGR4b1o3sEKToWbJxRhTIeQVFDJxXjr/mrOKpOqVeepPRzH8mFZWaDJMLLkYYxJe2qZ93DU1haVb9nNWnxaMPbcXTepUj3ZYCc2SizEmYR3KK+BfX6xi4rx0GtaqxoS/9mNY7+bRDqtCKDW5iMjFwCdeKZZ7gGOBh1X157BHZ4wx5fRTxm5GTU0hfWcWf0puzZgze1IvqWq0w6owgtmR+14vsZwAnI47j8rz4Q3LGBOvpkyB9u2hUiV3PWVKZNd/ICef+2amcfGE78ktKOSNawby+EVHHZZYoh1jRRDMZrEC7/os4HlVnSkiY8MXkjEmXk2ZAiNHQna2u79unbsPMGJE+Nf/1YrtjJmeypb9h7jyOP+FJqMdY0URTM9lk4i8APwJmC0i1YN8njGmghkz5rcf7SLZ2W56OO3JyuWOdxZx1as/kVS9ClOvP46x5/byW8H4SGK0Hk/wgum5/AkYBjypqnu986jcGd6wjDHxaP36sk0/UqrK7NSt3D8rjb3ZedxycmduOrkz1asELjRZ3hitx1M2wfRAWgAfqeoqERmCK3M/P5xBGWPiU6ATv4bjhLDb9h/iutcXctObP9OiXk1m3XwCd5zWrcTEciQxRqtXFq+CSS7TgAIR6Qy8DHQA3gxrVMaYuDRuHCQVO9g9KclNDxVV5Z2f1jP0qbnMXbmDu8/ozowbj6Nny7phjTHSvbJ4F0xyKVTVfOAC4BlVvR3XmzHGmMOMGAETJ0K7diDiridOPPLNRr+NdSi1G+dy04O76NGiLp/cdhLX/aFTmSoYlzfGSPbKEkEw70ieiFwKXA586E2zncWNMX6NGAEZGfD66+7+ZZcd2eC3G+tQ1q0DVSF7d3Uy5xzFubUG0aFxrSOKsbDQXQeT/CLRK0skwSSXq4DBwDhVXSsiHYA3whuWMSaeFQ1+u4Tw2+B3aQnG395Yd40uJDv78PpfuYcqceWVEtG9tsLVK0tUoqqlP0ikGtDVu7tCVfPCGlUIJScn64IFC6IdhjEVSvv2LqEU166d6ymASwhjxrgxi7Zt4cwzYfLkwwfNq1YvJC9HgJKLSyYl2Q99qInIQlVNLvfzS0su3h5ik4EM3DvcBrhCVeeVd6WRZMnFmMirVMn1WIoTcZuiiu/WWzTP/8+RUlpyAWjUCHbuLG/EprgjTS7BbBb7J3Caqv5BVU/ClYB5urwrNMYkvtIGv/3t1hv4f25wJfF37bKDGmNJMMmlqqquKLqjqiuxAX1jTAlKG/wO1+67dsxJ7AgmuSwQkZdFZIh3eRFYGO7AjDHxq2jwu7LP8YzZ2fDII+52uHbftWNOYkcwyeUGYAlwC3ArsBS4PpxBGWPi3yOPQEHB4dOWLoVevdzgfTjYMSexo9TaYqqaAzzlXYwxJihLlwaevnRpcIP0xdWoAXl5v09aYMecxJqAPRcRSRWRlECXSAZpjIkfRceqlKzsiaVaNXjpJcjPd4P/b7xhx5zEspJ6LmdHLApjTEKYMgWuusr1LkKpXTvXK/FNHiNGWDKJZQGTi6r6OQTKGGP8mzLFlXoJ4rjsoFWtCq++akkkHsXdSb9EZJiIrBCR1SIyOtrxGGN+OygylImlUSNLLPEsmJOFxQwRqQz8FzgV2Aj8JCKzVDXA0KExJhyKSresW+d2N/Y3wF4etWtDZmZolmWiK66SCzAAWK2q6QAi8jZwHm73aGNMBBQv3RKqxAKQlRW6ZZnoKnWzmIgcLyKfi8hKEUkXkbUikh6J4PxoBWzwub/Rm3YYERkpIgtEZMGOHTsiFpwxFcGtt/6+dEuo2HEqiSOYMZeXcce4nAD0B5K962jwt//i77byqupEVU1W1eQmTZpEICxjEt+UKdC4savhFQ52nEpiCWaz2D5V/TjskQRnI64qc5HWwOYoxWJMheGvinEoVa5sx6kkmmCSy1ci8gQwHcgpmqiqP4ctqsB+Arp4JyzbBFwC/CUKcRhTofirYhxKhYWWWBJNMMlloHftW9dfgZNDH07JVDVfRG4GPgUqA6+o6pJIx2FMRXMkBSFVS+/52FhL4gmmttgfIxFIsFR1NjA72nEYU5G0bev/zJLBKuqV3Hrr78dsbKwlMZVUW+yv3vUd/i6RC9EYE22j78vDz74zpRL57QReI0a4M0VaTbCKoaS9xWp513UCXIwxCU5Vef+XTbyw8SvqHruOsiYY1d+fwGvECMjIcOMsGRmWWBJVwOSiqi941w/4u0QuRGNMJBRVM65UyV3/58Vcrpm8gNveWUT7xrVYMLsRN9wgSBkLGtsJvPwr/non2ima4+0IfWNMiE2Z8vuxkHXr4JabKtP8rGo89PeeXHlceypXEp57Do4/3vVG1q+Hhg1duZbc3MDLt8H63yu+g8O6de4+JE5PTjSUleZiUHJysi5YsCDaYRgTk0rbi6tV60I2bgi89bx9+5IH+pOSbEzFn0CvW7t2blNhLBCRhaqaXPoj/Yu7qsjGmNAp7fiVzZtK/okoaZNX5cpwxRWWWPwJ9Lol0ibEYGqLNRORl0XkY+9+TxG5JvyhGWPCrbQfs9I2aZU0v6DAnTmycePEHVcor0CvWyJtQgym5zIJd9BiS+/+SuC2MMVjjImQnPwC6jUJfMrIYI4/GTfOPS6QvDw3lqP627iCJRj/r1uiHe8TTHJprKrvAoXgjpIHQlhk2xgTaQvX7eGsZ7+l8oA0qlQr/N38Ro2CGysZMcI9rl274Nabnf37XZMrIt/XLVGP9wkmuWSJSCO8HdxFZBCwL6xRGWPCIisnnwc+WMJFE74jOyef955sxaRXKh32I/fGG+5gx2B/6IqOWwk2wSTSuMKRSPTjfYLZFfkOYBbQSUT+BzQBLgprVMaYkPtm1Q7unp7Kxj0HuXxwO+4a1p3a1atAt9D8sI0bF1zl5EQaVzCBBVNb7GcR+QPQDXc+lRWqGnhDrTEmpuzLzmPc7KW8u2AjHRvX4t3rBjOgQ8OQr6coQZV0DEyijSuYwEpNLiJyQbFJXUVkH5CqqtvDE5YxJhQ+SdvKvTPT2J2Vy41DOnHLKV2oUbVy2NY3YsThvaApU35LNm3busSSaJt/jH/BbBa7BhgMfOXdHwL8gEsyD6rq62GKzRhTTjsyc7h/VhqzU7fSs0VdXr2yP71b1Yt4HMWTjak4gkkuhUAPVd0G7rgX4HnceV7mAZZcjIkRqsr0nzfx4IdLOZhXwJ2nd2PkSR2pWtmOlzaRFUxyaV+UWDzbga6qultEbOzFmBixcU82/5iRxryVO+jXrgGPXdiXzk1rRzssU0EFk1y+EZEPgfe8+xcC80SkFrA3XIEZY4JTWKi88eM6Hvt4OQo8cG4vLhvUjkqVyli+2JgQCia53IRLKMfj9hZ7DZimruJlTJ2l0piKZs2OA4yelsJPGXs4sUtjHhnehzYNSzhk3pgICWZXZAWmehdjTAzIKyjkxW/SeWbOKmpWrcyTFx/Fhce2Qsp6shVjwiTYXZEfA5riei6Cyzl1wxybMcaPJZv3cdfUFJZs3s+ZfZoz9txeNK1TI9phGXOYYDaLPQ6co6rLwh2MMSawQ3kF/PvLVUyYm06DpGpM+OuxDOvdItphGeNXMMllmyUWY6JrQcZu7pqWQvqOLC7u15oxZ/WgflK1aIdlTEDBJJcFIvIO8D6QUzRRVaeHKyhjjJOVk88Tn65g8vcZtKxXk9euHsBJXZtEOyxjShVMcqkLZAOn+UxTwJKLMWE0b6UrNLl530GuGNyeO0/vRq3qwXxljYm+YPYWuyoSgRhjnL3ZuTz80TKmLtxIpya1eO+6wSS3D32hSWPCKZi9xWrg6ov1An7dJUVVrw5jXMZUSLNTt3DfzCXsyc7l5j925uaTO4e10KQx4RJMH/t1YDlwOvAgMAKwAX5jQmj7/kPcN3MJnyzZSq+WdZl8dX96tYx8oUljQiWYanadVfVeIEtVJwNnAX3CFZCIjBWRTSKyyLuc6TPvbhFZLSIrROT0cMVgTKSoKu8u2MDQp+by5YrtjBrWnZk3HW+JxcS9YHouRcUp94pIb2Ar0D5sETlPq+qTvhNEpCdwCW7zXEtgjoh0VdWCMMdiTFhs2J3NP2ak8s2qnfRv34DxF/alUxMrNGkSQzDJZaKINADuxZ3uuDZwX1ij8u884G1VzQHWishqYADwfRRiMabcCgqV177P4IlPVyDAQ+f1YsRAKzRpEkswe4u95N2cC3QMbzi/ullELgcWAH9X1T1AK9xJyops9Kb9joiMBEYCtLUTdpsYsnp7JqOmpbJw3R7+0LUJ44b3pnUDKzRpEk8we4tVx1VFbu/7eFV9sLwrFZE5QHM/s8bgTkT2EO5YmoeAfwJX42qaFaf+lq+qE4GJAMnJyX4fY0wk5RUU8sLcNTz7xWqSqlfmqT8dxfBjrNCkSVzBbBabCewDFuJzhP6RUNWhwTxORF4EPvTubgTa+MxuDWwORTzGhFPapn3cOTWFZVtcockHzu1NkzrVox2WMWEVTHJprarDwh6JR0RaqOoW7+5wIM27PQt4U0Sewg3odwHmRyouY8rqUF4Bz8xZxYvfpNOwVjUm/LUfw3r767Abk3iCSS7fiUgfVU0NezTO4yJyNG6TVwZwHYCqLhGRd4GlQD5wk+0pZmLV/LW7GT0thfSdWfw5uQ3/OLMH9ZKqRjssYyImYHIRkVTcD3wV4CoRScdtFis6n0vfcASkqpeVMG8cMC4c6zUmFDIP5fH4Jyt4/Yd1tG5QkzeuGcgJXRpHOyxjIq6knsvZEYvCmATw1YrtjJmeypb9h7j6+A78v9O7klTNCk2aiingJ19V1wGIyCBgiapmevfrAD2BdRGJ0JgYtzsrl4c+XMqMXzbRpWltpl5/HP3aNYh2WMZEVTB/q54HjvW5n+VnmjEVjqryUeoW7p+5hH0H87jl5M7cdHJnqlexQpPGBJNcRFV/PVZEVQtFxPr6pkLbtv8Q97yfxudLt9GnVT3e+NtAerSoG+2wjIkZwSSJdBG5BddbAbgRSA9fSMbErqJCkw9/tIzc/ELuPqM715zQgSqVg6kBa0zFEUxyuR54FrgHt/fYF3ilVYypSNbvymb09BS+W7OLgR0aMv7CvnRoXCvaYRkTk4KpLbYdV43YmAqpoFCZ9F0GT366gsqVhHHDe3Np/7ZWaNKYEtjYiTElWLktk7umprBow15O7t6Uh8/vTcv6NaMdljExz5KLMX7k5hcyYe4a/v3lKmpXr8K/Ljmac49qaYUmjQmSJRdjilm8YS+jpqWwfGsm5x7VkvvP6Umj2lZo0piyKKn8yx0lPVFVnwp9OMZEz8HcAp6Zs5IXv0mnaZ0avHR5MkN7Not2WMbEpZJ6LnW8625Af1xVYoBzgHnhDMqYSPshfRejp6WQsSubSwe05e4zu1O3hhWaNKa8Sir/8gCAiHwGHOtT/mUs8F5EojMmzDIP5TH+4+VM+XE97Rol8ea1AzmukxWaNOZIBTPm0hbI9bmfizsrpTFx7cvl2xgzI41t+w9x7YkduOPUbtSsZqVbjAmFYJLL68B8EZmBO4hyOPBaWKMyJox2HcjhwQ+XMnPRZro2q83zfz2eo9vUj3ZYxiSUYA6iHCciHwMnepOuUtVfwhuWMaGnqsxavJkHPlhK5qE8bhvahRuHdKZaFSvdYkyoBbsrchKwX1VfFZEmItJBVdeGMzBjQmnLvoPcMyONL5Zv56g29Xn8wr50a16n9CcaY8ql1OQiIvcDybi9xl4FqgJvAMeHNzRjjlxhofL2Txt4dPYy8goLueesHlx1fAcqW+kWY8IqmJ7LcOAY4GcAVd3snTDMmJiWsTOL0dNT+CF9N4M7NmL8hX1o18gKTRoTCcEkl1xVVRFRABGxb6eJaQWFyivfruWfn6+gaqVKjL+gD3/u38ZKtxgTQcEkl3dF5AWgvohcC1wNvBTesIwpnxVbM7lr6mIWb9zH0B5Nefj8PjSvVyPaYRlT4QSzt9iTInIqsB837nKfqn4e9siMKYPc/EL++9Vqnvt6NXVrVOXflx7D2X1bWG/FmCgJZkD/MVUdBXzuZ5oxUbdow17umrqYldsOcP7RLbnvnF40rFUt2mEZU6EFs4P/qX6mnRHqQIwpq4O5BTz84VIueO5/ZB7K55Urk3nmkmMssRgTA0qqinwDcCPQSURSfGbVAb4Ld2DGlOS71TsZPT2V9buz+eugtowa1p06VmjSmJhR0maxN4GPgUeB0T7TM1V1d1ijMiaAfQfzeHT2Mt7+aQMdGtfi7ZGDGNSxUbTDMsYUU1JV5H3APhH5F7DbpypyHREZqKo/RipIYwA+X7qNe95PZUdmDtf9oSO3D+1KjapWaNKYWBTMmMvzwAGf+1netHITkYtFZImIFIpIcrF5d4vIahFZISKn+0zvJyKp3rxnxXYDqjB2Hsjh5jd/5trXFtAgqRrv33Q8d5/RwxKLMTEsmONcRFW16I6qForIkZ4eOQ24AHjhsBWJ9AQuAXoBLYE5ItJVVQtwCW0k8AMwGxiG22xnEpSqMnPRZh74YAlZOQX8/dSuXD+kE1UrW6FJY2JdMEkiXURu4bfeyo1A+pGsVFWXAf6OQTgPeFtVc4C1IrIaGCAiGUBdVf3ee95rwPlYcklYm/ceZMyMVL5asYNj2rpCk12aWdUhY+JFMMnleuBZ4B7c+Vy+wPUgwqEVrmdSZKM3Lc+7XXy6XyIyEi/Gtm3bhj5KEzaFhcqU+et57OPlFBQq953dkyuOa2+FJo2JM8Ecob8dt6mqTERkDtDcz6wxqjoz0NP8hVDCdL9UdSIwESA5OTng40xsWbszi1HTUpi/djcndG7Moxf0oU3DpGiHZYwph5KOc7lLVR8XkX/j54dcVW8pacGqOrQc8WwE2vjcbw1s9qa39jPdJID8gkJe+nYtT3++kmpVKvH4hX25OLm1lW4xJo6V1HNZ5l0viEQgnlnAmyLyFG5AvwswX1ULRCRTRAYBPwKXA/+OYFwmTJZu3s9d0xaTtmk/p/VsxkPn96ZZXSs0aUy8K+k4lw+868mhXqmIDMclhybARyKySFVPV9UlIvIusBTIB27y9hQDuAGYBNTEDeTbYH4cO5RXwH++XM2EuWuon1SV50Ycyxm9m1tvxZgEIT57GR8+Q+QDSh7XODdcQYVScnKyLlgQyc6XKc3Cdbu5a2oKa3ZkccGxrbj3rJ40sHpgxsQUEVmoqsmlP9K/kjaLPeldX4AbmH/Du38pkFHeFZqKKysnnyc+XcHk7zNoWa8mk67qz5BuTaMdljEmDEraLDYXQEQeUtWTfGZ9ICLzwh6ZSSjfrNrB3dNT2bjnIJcPbsddw7pTu/qRHotrjIlVwXy7m4hIR1VNBxCRDrixEmNKtS87j3Gzl/Lugo10bFyLd68bzIAODaMdljEmzIJJLrcDX4tI0VH57YHrwhaRSRifpG3l3plp7M7K5YYhnbj1lC5WD8yYCiKYgyg/EZEuQHdv0nKvPIsxfm3PPMTYWUuYnbqVni3q8uqV/endql60wzLGRFAwpzlOAu4A2qnqtSLSRUS6qeqH4Q/PxBNVZfrPm3jww6UczCvgztO7MfKkjlZo0pgKKJjNYq8CC4HB3v2NwHuAJRfzq417svnHjDTmrdxBv3YNeOzCvnRuWjvaYRljoiSY5NJJVf8sIpcCqOpBO5eKKVJYqLzx4zoe+3g5Cjxwbi8uG9SOSlZo0pgKLZjkkisiNfEOqBSRToCNuRjW7DjA6Gkp/JSxhxO7NOaR4VZo0hjjBJNc7gc+AdqIyBTgeODKcAZlYlteQSEvfpPOM3NWUbNqZZ68+CguPLaVlW4xxvyqxOQiIpWABrij9AfhSt/fqqo7IxCbiUFpm/YxaloKSzbv54zezXngvF40rWOFJo0xhysxuXinNL5ZVd8FPopQTCYGHcor4NkvVvHCvHQaJFXj+RHHckafFtEOyxgTo4LZLPa5iPw/4B0gq2iiqu4OW1QmpizI2M1d01JI35HFxf1aM+asHtRPskKTxpjAgkkuV3vXN/lMU6Bj6MMxseRATj5PfLKc135YR8t6NXnt6gGc1NUq/xhjShfMEfodIhGIiS1zV+7gH9NT2bzvIFcMbs+dp3ejlhWaNMYEKZgj9GsANwIn4Hos3wATVPVQmGMzUbA3O5cHP1zK9J830alJLaZeP5h+7azQpDGmbIL5K/oakMlvpxW+FHgduDhcQZnomJ26hftmprE3O4+b/9iZm0/ubIUmjTHlEkxy6aaqR/nc/0pEFocrIBN52/cf4r6ZS/hkyVZ6t6rL5KsH0KulFZo0xpRfMMnlFxEZpKo/AIjIQOB/4Q3LRIKq8t7CjTz84VIO5Rcyalh3rj2xA1Ws0KQx5ggFk1wGApeLyHrvfltgmYikAqqqfcMWnQmbDbuz+ceMVL5ZtZMB7Rsy/sI+dGxihSaNMaERTHIZFvYoTMQUFCqvfZ/B45+soJLAQ+f3ZsSAtlZo0hgTUsHsirwuEoGY8Fu9PZO7pqbw8/q9DOnWhHHD+9Cqfs1oh2WMSUB24EIFkFdQyAtz1/DsF6tJql6Zp/98FOcfbYUmjTHhY8klwaVu3MedUxezfGsmZ/VtwQPn9qJx7erRDssYk+AsuSSoQ3kFPD1nJS/OS6dx7epMvKwfp/VqHu2wjDEVhCWXBPRj+i5GT09l7c4sLunfhrvP7EG9mlWjHZYxpgKx5JJAMg/l8dgny3njh/W0aViTKX8byPGdG0c7LGNMBRSVo+VE5GIRWSIihSKS7DO9vYgcFJFF3mWCz7x+IpIqIqtF5Fmx0ejDfLV8O6c9PY8pP67nmhM68OltJ1liMcZETbQOxU7Dnd1ynp95a1T1aO9yvc/054GRQBfvYsffALuzcrnt7V+4atJP1K5ehWk3HMe9Z/ckqZp1Sk1smTIF2reHSpXc9ZQp0Y7IhFNUfoFUdRkQ9K6wItICqKuq33v3XwPOBz4OU4gxT1X5KHUL989cwr6DedxyShdu+mMnqlexQpMm9kyZAiNHQna2u79unbsPMGJE9OIy4ROLRaQ6iMgvIjJXRE70prUCNvo8ZqM3rULatv8QI19fyM1v/kKrBjX54P9O4I5Tu1piMTFrzJjfEkuR7Gw33SSmsPVcRGQO4G/f1zGqOjPA07YAbVV1l4j0A94XkV6Avy6OlrDukbhNaLRt27ZsgccwVeXdBRt4+KNl5OYX8o8zu3P18VZo0sS+9evLNt3Ev7AlF1UdWo7n5AA53u2FIrIG6IrrqbT2eWhrYHMJy5kITARITk4OmITiyfpd2YyensJ3a3YxsENDHruwL+0b14p2WMYEpW1btynM33STmGLqL6+INBGRyt7tjriB+3RV3QJkisggby+xy4FAvZ+EUlCovPRNOqc9M5eUjft4ZHgf3rp2kCUWE1fGjYOkpMOnJSW56SYxRWVAX0SG485s2QT4SEQWqerpwEnAgyKSDxQA16vqbu9pNwCTgJq4gfyEH8xfuc0Vmly0YS8nd2/KuOG9aVHPCk2a+FM0aD9mjNsU1ratSyw2mJ+4RDUhthoFlJycrAsWLIh2GGWSm1/I81+v4T9fraJOjarcf05Pzj2qpRWaNMZEjIgsVNXk0h/pnx0MEWMWb9jLqGkpLN+ayXlHt+S+s3vSyApNGmPijCWXGHEwt4CnPl/By9+upWmdGrx0eTJDezaLdljGGFMullxiwPdrdjF6egrrdmXzl4FtGX1Gd+rWsEKTxpj4ZcklivYfyuPR2ct5a/562jVK4s1rB3JcJ6sHZoyJf5ZcomTO0m3c834a2zMPMfKkjtw+tCs1q9kR9saYxGDJJcJ2HcjhgQ+WMmvxZro1q8OEy/pxdJv60Q7LGGNCypJLhKgqsxZv5oEPlpJ5KI/bh3blhiGdqFYlpo5jNcaYkLDkEgFb9h3knhlpfLF8O0e1qc/jF/alW/M60Q7LGGPCxpJLGBUWKm/9tJ5HZy8nv7CQe87qwVXHd6ByJTsY0hiT2Cy5hEnGzixGT0/hh/TdHNepEeMv6EvbRkmlP9EYYxKAJZcQyy8o5JX/reWfn62kWuVKjL+gD3/u38ZKtxhjKhRLLiG0fOt+Rk1NYfHGfQzt0YyHz+9N83o1oh2WMcZEnCWXEMjJL+C/X63hua9WU69mVf7zl2M4q08L660YYyosSy5H6Jf1exg1LYWV2w5w/tEtue+cXjSsVS3aYRljTFRZcimn7Nx8/vnZSl7531qa163Bq1f254/dm0Y7LGOMiQmWXMrhf6t3Mnp6Cht2H+Svg9oyalh36lihSWOM+ZUllzLYdzCPR2cv4+2fNtChcS3eGTmIgR0bRTssY4yJOZZcgvTZkq3c834au7Jyuf4PnbhtaBdqVLVCk8YY448ll1LsPJDD2FlL+DBlCz1a1OXlK/rTp3W9aIdljDExzZJLAKrK+4s28cAHS8nOKeDvp3bl+iGdqFrZCk0aY0xpLLn4sWnvQcbMSOXrFTs4tm19Hr+oL52bWqFJY4wJliUXH4WFypT56xk/exkKjD2nJ5cNbm+FJo0xpowsuXjSdxxg9LRU5mfs5sQujXlkeB/aNLRCk8YYUx4VPrnkFxTy0rdrefrzlVSvUoknLurLRf1aW+kWY4w5AhU6uSzdvJ9R01JI3bSP03s146HzetO0rhWaNMaYI1Uhk8uhvAL+8+VqJsxdQ/2kajw/4ljO6NMi2mEZY0zCqHDJZeG63dw1NYU1O7K48NjW3Ht2D+onWaFJY4wJpQqTXLJy8nni0xVM/j6DlvVqMvnqAfyha5Noh2WMMQkpKkcEisgTIrJcRFJEZIaI1PeZd7eIrBaRFSJyus/0fiKS6s17Vsow4v7Nqh2c/sw8Jn2XweWD2vHp7SdZYjHGmDCK1uHmnwO9VbUvsBK4G0BEegKXAL2AYcBzIlJUwOt5YCTQxbsMC2ZFG/cc5LKX51OtciXeu34wD5zXm9rVK0yHzRhjoiIqyUVVP1PVfO/uD0Br7/Z5wNuqmqOqa4HVwAARaQHUVdXvVVWB14Dzg1nXnuxcbhzSidm3nkj/9g1D2xBjjDF+xcJf+KuBd7zbrXDJpshGb1qed7v4dL9EZCSulwOQM+qMHmmjQhZuzGkM7Ix2EGGSyG0Da1+8S/T2dTuSJ4ctuYjIHKC5n1ljVHWm95gxQD4wpehpfh6vJUz3S1UnAhO9dSxQ1eQyhB5XErl9idw2sPbFu4rQviN5ftiSi6oOLWm+iFwBnA2c4m3qAtcjaePzsNbAZm96az/TjTHGxKBo7S02DBgFnKuq2T6zZgGXiEh1EemAG7ifr6pbgEwRGeTtJXY5MDPigRtjjAlKtMZc/gNUBz739ij+QVWvV9UlIvIusBS3uewmVS3wnnMDMAmoCXzsXYIxMZSBx6BEbl8itw2sffHO2lcC+W2LlDHGGBMadlpFY4wxIWfJxRhjTMglTHKJdEmZSBORi0VkiYgUikiyz/T2InJQRBZ5lwk+8+K+fd68uH//fInIWBHZ5POenekzz29b44mIDPPiXy0io6MdTyiISIb3WVtUtIuuiDQUkc9FZJV33SDacQZLRF4Rke0ikuYzLWB7yvW5VNWEuACnAVW8248Bj3m3ewKLcTsQdADWAJW9efOBwbjjaD4Gzoh2O0poXw/cQU1fA8k+09sDaQGekwjtS4j3r1hbxwL/z8/0gG2NlwtQ2Yu7I1DNa0/PaMcVgnZlAI2LTXscGO3dHl30mxMPF+Ak4Fjf345A7Snv5zJhei4awZIy0aCqy1R1RbCPT6D2JcT7FyS/bY1yTGU1AFitqumqmgu8jWtXIjoPmOzdnkwcff5UdR6wu9jkQO0p1+cyYZJLMVfz267KrYANPvOKSse0ogwlZWJcBxH5RUTmisiJ3rREaV+ivn83e5twX/HZ/BCorfEkEdrgjwKfichCr7wUQDN1x+DhXTeNWnShEag95XpPY6G2WNCiWVImEoJpnx9bgLaquktE+gHvi0gvEqd9cfP++SqprbgK3w/h4n0I+CfuD1FMtylIidAGf45X1c0i0hR3fN7yaAcUQeV6T+MquWiCl5QprX0BnpMD5Hi3F4rIGqArCdI+4uj98xVsW0XkReBD726gtsaTRGjD76jqZu96u4jMwG0W2iYiLVR1i7eZdntUgzxygdpTrvc0YTaLVdSSMiLSRLxz3ohIR1z70hOlfSTg++d9cYsMB4r22PHb1kjHd4R+ArqISAcRqYY7P9OsKMd0RESklojUKbqN23koDdeuK7yHXUGcfP5KEKg95ftcRnuvhRDu/bAat11wkXeZ4DNvDG4PhxX47FEEJOM+JGtwJWkk2u0ooX3Dcf8gcoBtwKfe9AuBJbi9OX4Gzkmk9iXK+1esra8DqUCK98VtUVpb4+kCnIk7CeAa3CbPqMd0hO3p6H2/FnvftTHe9EbAF8Aq77phtGMtQ5vewm1SLzqdyTUltac8n0sr/2KMMSbkEmazmDHGmNhhycUYY0zIWXIxxhgTcpZcjDHGhJwlF2OMMSFnycUkJBEZIiLHHeEyDpThsZNE5KIjWV+oiMh3ZXx8zMRuEoclF5OohgBHlFzilapWyHab2GLJxcQNEXnfKxy4xKd4YNH5Q34WkcUi8oWItAeuB273zr9xYvF/50W9EhGp7T3nZ+98HaVW8BWRy72ik4tF5HWfWSeJyHcikl60rkDLF3cenmUi8qLXns9EpKY3r7+3/O/FnacozZte2bv/kzf/ugDxFbVtiIh8LSJTxZ3raIpXzaCktp3iFUFN9YpqVvemjxeRpd56n/SmXSwiad7rMK+0181UMNE+UtQudgn2gnfEMFATd2R+I6AJrjJDh2KPGYvPOVOAScBFPvcPeNdVcKX7ARrjKj2I72OKxdALd5Ry42LrmwS8h/vD1hNXdj7g8nHn4ckHjvbmvQv81budBhzn3R6Pd84NYCRwj3e7OrCgqN3FYixq2xBgH64WVCXge+AEP4+fBFwE1PBey67e9NeA24CGXpuLXpf63nUq0Mp3ml3sUnSxnouJJ7eIyGLc+Xra4GocDQLmqTvPBKpa/BwVpRHgERFJAebgSok3K+HxJwNTVXWnn/W9r6qFqrrUZxklLX+tqi7ybi8E2os7g2odVS0aN3nTZ/mnAZeLyCLgR1xy7VJK++ar6kZVLcSVRWpfwmO7eTGt9O5Pxp1Uaj9wCHhJRC4Aimr3/Q+YJCLX4k4SZsyv4qoqsqm4RGQIMBQYrKrZIvI17p+2EFxJ93y8zcDepqFq3vQRuN5PP1XNE5EMb7kBQylhfTnFHlfa8n0fX4DrkZW02UqA/1PVT0t4TEkxFVDyd97vulU1X0QGAKfgClHeDJysqteLyEDgLGCRiBytqrvKEJtJYNZzMfGiHrDHSyzdcT0WcJt6/uBVa0VEGnrTM4E6Ps/PAPp5t88Dqvosd7v3w/9HoF0pcXwB/ElEGhVbX0lxB718Vd2DV+3Zm3SJz+xPgRtEpKq37q5eld5QWY7rPXX27l8GzBWR2kA9VZ2N20x2tLf+Tqr6o6reB+zk8LLspoKznouJF58A13ubl1bgNo2hqju8wf3pIlIJdw6KU4EPgKneAPr/AS8CM0VkPi5BZHnLnQJ8ICILcJuNSjwJlKouEZFxuB/dAuAX4MoSnlKm5XuuAV4UkSzga9y4CcBLuM1aP3u9rx2E8NS6qnpIRK4C3hORKrjy+RNwYy4zRaSop3i795QnRKSLN+0LXNVgYwCsKrIxsUZEaqtq0R5fo3El+W+NcljGlIn1XIyJPWeJyN247+c6Su4ZGROTrOdijDEm5GxA3xhjTMhZcjHGGBNyllyMMcaEnCUXY4wxIWfJxRhjTMj9f7WK6dOmpZh0AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "x = np.linspace(-200, 200)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.plot(acctual_influence_2, predict_influence_2, 'o', 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')\n",
    "plt.ylim(-200, 100)\n",
    "plt.xlim(-200, 100)\n",
    "# plt.title('Influence function on Iris dataset')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "0562c072",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAEWCAYAAACqitpwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABGlklEQVR4nO2dd5xVxfXAv2eXXXpditSlCCIgomA3aiyxizUxwW5EUWNLIhjU4E+JXaNJ1KAYUVCigA07KhIbCEpv0quw9KUt7O75/TH3ydvHa7uvvz3fz+d+3rtz7505d245d+acOSOqimEYhmHEk5xUC2AYhmFkH6ZcDMMwjLhjysUwDMOIO6ZcDMMwjLhjysUwDMOIO6ZcDMMwjLhTbZWLiLQQkUkiUiwij4vIEBEZmWq5oiVQ/iSXvV1EOia5zNoi8q6IbBWRN5JZdrSIyFUi8mWC8s6o+zMaRGSOiJyUajnSARFpLyIqIjVSLUu8yCrlIiLLROTUKHfvD2wAGqjqHxMoVqJIivwiMlFEfu+fpqr1VHVJosoMwcVAC6BAVS9JctlxR0ReEpEHUi1HKlHV7qo6MdVyZAMi0kVE3hCRDd4H2EwRuUNEclMlU1Ypl0pSCMzVzB1FmunyV5ZCYKGqlqZakEwmm76MDYeIdAImAyuBQ1S1IXAJ0AeoX8m84nd/qGrWLMAy4FTv/1XAl8BjwGZgKXCmt+0lYC+wB9gOnAoMAUZ6208CVoXJOwcYBCwGNgKvA028be0BBa4EVuBaF4P98skF/uIdWwxMA9p627oCnwCbgAXAr0OcZzD5XwIe8Nunwjl48v8JmAlsBf4L1PLb3heYDmzzZDsDGAqUAbu9cv7p7avAgd7/hsDLQBGwHLgbyIl0DUKc18HARGALMAc4z0u/zzvXvZ4c1wY5Nly9Hgt85533d8CxfsdNBB4AvvbyfhcoAEZ5dfEd0N5vfwVuAZZ41/bRwPP12zfo9cS1Ov2v37teeitgrFeXS4Fb/PIawr778z3gDwHnPxM4P0i9tPdkvhZ3P07y0q8B5nnX5SOgMOAcbwR+9OryfqAT8I1XJ68D+X77Xwcs8s7zHaCVl/4c8FiAPG8DdwR5poZ4+b7slTkH6ON33OHAD962N3D37wOB5+v3fN6Nux/Xe3k2jPL5DPlsBynnJGAV8EevnLXA1X7bwz0bubjnYgPuXrrJk6uG37HDvTxX4+7R3BByjATei/BuPM+r0y24e/7ggHfDQO8eKgFq+NVBMTAXuKDS7+OqvsjTcWF/5bLXu/FzgQHAGkC87S9R8WU8hOiVy23At0AboCbwb+C1gJv3eaA2cKh3wQ72tv8ZmAUcBIi3vQCoi/vyuNq7uId7N173EOcaKH/geoVz8OSfgnuBNcG9WG7wth2Je/Gehnu4WgNdvW0Tgd8HlO2vXF7GvTDqe+e+EO/lH+kaBOSZh3tB/QXIB072buyDAq9PiPoIVa9NcC/Qy716/a23XuB3fotwL8+GuAdpIU5h1/DO7z8B5/65l287b9/f+53vl97/sNczyPXKwSnEe73z74h76Zwe5P78NTDZ79hDcS/C/CD10t6T+WVPptrA+d45H+zJdjfwdcA5vgM0ALrj7t9PPZl8dXSlt+/J3nkdjnsW/sE+BXaCVwe+Z64xsIt9ymcZFZXLbuAs3L3yIPCtty0f93K+FXefXIhTzKGUyzXe+XUE6gHjgFeifD5vI8SzHaSck4BS4P88uc4CdgKNo3g2bgDmA21x99LnVFQub3ll1wWa457d60PI8RN+Si3I9i7ADtzznQfc6dVPvt91mO7JUttLuwT3rsgBfuMd37JS7+NEvuyTvbC/clnkt62Od/EOCPFwDyF65TIPOMVvW0vcS7SG383bxm/7FOBS7/8CoG8Q2X8D/C8g7d/AX0Oca6D8gesVzsGT/zK/9UeA5/zKeTJEORMJoVxwL4ESoJvftuuBidFcg4A8f+E9JDl+aa8BQwKvTwg5Q9Xr5cCUgLRvgKv8zs//y/Vx4AO/9XOB6QHnfobf+o3Ap37n61MuYa9nkOt1FLAiYP+78BQbFe/PmrhWQmdv/THgmRD14rsfO/qlfYBf6w/3AtmJ13rx9j/Ob/s0YGBAHf3d+z8ceMRvWz3cs9Aep+RXACd4264DPgvxTA0BJvht6wbs8v6fgPt6F7/tXxJauXwK3Oi3fhDRP58hn+0g5ZyEU5Y1/NLWA0cT+dn4DO/jzlv/lSdXDZxtsQTvRe9t/y3weYjz3YvfPRlk+z3A6wHXezVwkt91uCbU8d4+0wnyfIVbsr3/9SffH1XdKSLgbv5YKQTeFJFyv7Qy3E2xX9m4B9dXbltcczNYnkeJyBa/tBrAKzFLG1qmVn4yvV+F/Jqy76vSx3Jcy2e/MiNcg1bASlX1r9PAvMIRql5bBcgXLN91fv93BVkPlHdlQF6t2J/KXs9CoFXA/rnA/wJ3VNUSEXkduExE7sO9eC4OkW8wmQuBpwK8DAVXJ766ilQnB3j/WwHf+8m2XUQ2Aq1VdZmIjPbkmwT8DteFE4rA+7OWZwNoBaxW7y0X5HwCCbzmy9n30g5Vlu8ah3u2Vwcpa6NWtAP68or0bLRi//vIRyGuhbHWe17AKYRQ57wRpwRDUaE+VLVcRFZS8RmokLeIXAHcgVPG+J1T1FRng344duC+sgHwPC6a+W1fibMdNPJbaqlqsJsvkJW4Lphg6V8E5FlPVQdURWb2PfzREEomcF9TodiA+2oq9EtrR/CHMBJrgLYi4n9PViavUOewJkC+yuYbjLYBea0JIU+46xlYryuBpQH711fVs0LIMALoB5wC7FTVbyLIHPhivj6grNqq+nWEPIJRoX5FpC6uO9JXv68BF4tIIa51NrYKZawFWovfm5aK1yCsTLhrVEpFBRmKWJ5tfyI9G2vZ/z7yl6EEaOonQwNV7R6irAnARWFkCbxG4pXtf07qt70Q1214M677uBEwG/cBEjWmXIKzEPfVdLaI5OH6pGv6bX8OGOpdBESkmYj0jTLvF4D7RaSzOHqKSAEwHugiIpeLSJ63HCEiB0eZ73TgLBFpIiIH4PqOo2U4cLWInCIiOSLSWkS6etvW4fqu90NVy3AGz6EiUt+rjzsI/3Uaisk4BXmnd+4n4bqkRkd5fKh6fR9Xr78TkRoi8htcl8v4Ksjo488i0lhE2uLsAP8Nsk+k6xlYr1OAbSIy0BvTkysiPUTkiGACeMqkHNdFVdnW7XPAXSLSHUBEGopIVd27X8XdO71EpCbwN5w9aJkn5w84g/YLwEequqUKZXyDaz3c7F3Dvjg7YSheA24XkQ4iUs+T6b8anadhLM/2z0TxbLwO3CIibUSkMc6A7jt2LfAx8LiINPCeyU4icmKI4v4KHCsij3rPPiJyoIiMFJFGXllne893Hs4BoQTnxBKMujhlU+TldTXQo7J1YMolCKq6FdeX/gJOu+/AeYX4eApn8PxYRIpxBsCjosz+CdzF/hjneTMc17dajOt3vRT3pfET8DAVlVo4XgFm4PpPPyb4Cy8oqjoFZ3h+EmfY/4J9XzpP4b48N4vI00EO/wOufpbg+sFfBV6Mtmw/GfbgPFrOxH31PQNcoarzo8wiVL1uBM7BPVAbccbMc1R1Q2Vl9ONtnB1iOs5za3iQ84l0PYcD3URki4i85b2MzgV64TzFNuDuv4Zh5HgZOIRKKnNVfdOTZbSIbMN9lZ5ZmTz88voU16c/Fvc13gl3zv68hnOQeLWKZezBGfGvxXk7XYZT3iUhDnkR9zxMwtXlbtx9Gg2xPNuBhHs2nsd56c3AdSuOCzj2Cly32lycA8oYQnR9qepi4BhcF9YcEdmKux5TgWJVXYCrs3/g7qtzgXO9eg2W31zcR8s3uI+gQ4CvKnXm7PPiMAwjCkREcYb0RWkgyxVAf1U9PtWyJBsRmYxzSPlPqmUxgmMtF8PIQESkDq51PSzVsiQDETlRRA7wusWuBHoCH6ZaLiM0KVMuIlJLRKaIyAxxMYbu89KbiMgnIvKj99vY75i7RGSRiCwQkdNTJbthpBLv3i/CdVlUqaspAzkI14W0FdfFebFnmzDSlJR1i3keC3U918U8XJ/krbi+1U2q+pCIDMINSBooIt1wfbdH4lzrJgBdvL5qwzAMI41IWctFHdu91TxvUVwYkhFe+gjcaGK89NGqWqKqS3EjTMN5jBiGYRgpIqWDKL3xI9Nwo73/paqTRaSFr7mrqmtFpLm3e2uc54aPVYQYYCci/XHxm6hbt27vrl27BtvNMIwsZOFCKC4Ovq1DB2jSJLnyRMumTbB8OZT7Dd/MyYHCwuTJvKOklFWbd7GnrJw9Py3aoKrNIh8VnJQqF69Lq5fni/2miITzpQ42gCdon56qDsMzdPbp00enTp0aq6iGYWQQp54Kn366b71mTRg+HPr1S51M0TBqFAweDCtWQLt2MHRocmQu3r2Xhz6Yz6jJK+jVpDYPX9iT4zo3C4xsUSnSIvyLqm4RkYm4SLzrRKSl12ppiYvVA66l4j+itQ3BR0YbhlHNmTAh1RJUjX79kq8AP5u/jsFvzmbdtt38/vgO3PGrLtTJj101pNJbrJnXYkFEauMGWc3HDWC60tvtStyANbz0S0Wkpoh0ADrjRjUbhmEYlWTTjj3cNvoHrnlpKvVr1WDsgGO5+5xucVEskNqWS0tghGd3ycFF7RwvIt8Ar4uIb/6JSwBUdY64YH1zcXGCbjJPMcMwjMqhqrw7cy1D3plD8e693HpKZ2765YHk14hvWyPrR+ibzcUwDMPx09bd3P3WbCbMW8ehbRry8MU96XpAg6D7isg0Ve1T1bLSwuZiGIZhJA5VZfR3K/nbe/PYW17O3WcfzNXHdSA3p1KBjiuFKRfDMIwsZvnGHQwaO4tvlmzkmI4FPHTRIRQW1E14uaZcDMMwspCycuU/Xy3lsY8XkJeTw4MXHsKlR7RFJHGtFX9MuRiGYWQZC34q5s6xM5mxcgunHtycB84/hAMa1kqqDKZcDMMwsoQ9peU8M3ER//p8EfVr5fH0bw/j3J4tk9Za8ceUi2EYRhYwfeUWBo6ZyYJ1xZzfqxX3ntudJnXzUyaPKRfDMIwMZteeMh7/eAEvfrWUFg1q8eJVfTi5a4tUi2XKxTAMI1P5evEGBo2dxYpNO+l3VDsGndmV+rXyUi0WYMrFMAwj49i2ey8Pvj+P16aspH1BHV677miO6VSQarEqYMrFMAwjg5gwdx2D35pFUXEJ15/QkdtO7ULt/NxUi7UfplwMwzAygI3bSxjy7lzenbGGrgfU5/kr+tCzTaNUixUSUy6GYRhpjKryzow1DHlnDttLSrnjtC7ccGKnuAeajDemXAzDMNKUNVt2cfdbs/ls/np6tW3Eoxf3pHOL+qkWKypMuRiGYaQZ5eXKq1NW8NAH8ykrV+49pxtXHts+oYEm440pF8MwjDRi6YYdDBo7k8lLN3HcgQU8eEFP2hXUSbVYlcaUi2EYRhpQWlbO8C+X8sQnC8mvkcMjF/Xkkj5tUhK6JR6kt0XIMAwjAxk1Ctq3h5wc9ztqVPj9563dxoXPfs2DH8znhC7NmHDHifw6iRGME4G1XAzDMOLIqFHQvz/s3OnWly936wD9+lXct6S0jH99tohnJi6mYe08/vm7wzj7kNQEmow3KWu5iEhbEflcROaJyBwRudVLHyIiq0Vkurec5XfMXSKySEQWiMjpqZLdMAwjFIMH71MsPnbudOn+TFu+mbOf/pKnP1vEeYe2YsIdJ3JOz1ZZoVggtS2XUuCPqvq9iNQHponIJ962J1X1Mf+dRaQbcCnQHWgFTBCRLqpallSpDcMwwrBiRfj0nXtKefSjBbz09TJaNqjFf64+gl8e1Dx5AiaJlCkXVV0LrPX+F4vIPKB1mEP6AqNVtQRYKiKLgCOBbxIurGEYRpS0a+e6woKlf/njBu56cyYrN+3iimMKufOMrtSrmZ3WibQw6ItIe+AwYLKXdLOIzBSRF0WksZfWGljpd9gqwisjwzCMpDN0KNQJ8ByuXVvp0Xc5lw2fTI2cHF6//hj+r2+PrFUskAbKRUTqAWOB21R1G/As0AnohWvZPO7bNcjhGiLP/iIyVUSmFhUVxV9owzCMEPTrB8OGQWEhiEDzlqUccPZs5tWdw4CTOvHBrb/gyA5NUi1mwkmp2hSRPJxiGaWq4wBUdZ3f9ueB8d7qKqCt3+FtgDXB8lXVYcAwgD59+gRVQIZhGImiXz/41XklDHlnDu/NWkvXlg145OLj6NG6YapFSxopUy7iXCKGA/NU9Qm/9JaePQbgAmC29/8d4FUReQJn0O8MTEmiyIZhGBFRVd78YTX/N34uO0vK+PPpB9H/hI7k5aa8oyippLLlchxwOTBLRKZ7aX8BfisivXBdXsuA6wFUdY6IvA7MxXma3WSeYoZhpBOrt+ziL+Nm8cXCInoXNubhi3pyYPN6qRYrJaTSW+xLgttR3g9zzFBgaMKEMgzDqALl5crIyct5+IP5KHDfed25/OhCcjIo0GS8yV5XBcMwjCSwuGg7g8bO5Ltlm/lF56b87YJDaNsk8wJNxhtTLoZhGFVgb1k5z/9vCX+f8CO183J57JJDuejw1lkzwj5WTLkYhmFUkjlrtnLnmJnMWbONM3scwH19u9O8fq1Ui5VWmHIxDMOIkt17y/jHZz/y3BdLaFwnn2f7Hc6Zh7RMtVhpiSkXwzCMKJi6bBN3jp3JkqIdXNy7DXeffTCN6uSnWqy0xZSLYRhGGHaUuECTI75ZRquGtRlxzZGc2KVZqsVKe0y5GIZhhGDSwiLuGjeLNVt3ceUx7fnT6QdldTyweGK1ZBiGEcCWnXt44L15jJm2io7N6vLG9cfQp332xwOLJ6ZcDMMw/Phg1lrueXsOm3fu4aZfduIPJ3emVl5uqsXKOEy5GIZhAOuLd/PXt+fwweyf6N6qASOuOYLurapPoMl4Y8rFMIxqjaoyZtoq7h8/l92l5Qw8oyvX/aIDNapZoMl4Y8rFMIxqy8pNO/nLm7P4348bOKJ9Yx66qCedmlXPQJPxxpSLYRjVjvJy5eVvlvHIRwsQ4P6+3el3VPUONBlvTLkYhlGtWLS+mIFjZzFt+WZO7NKMoRf0oE1jCzQZb0y5GIZRLdhbVs6wSUt4asKP1KmZyxO/PpQLDrNAk4nClIthGFnP7NVb+fOYmcxbu42ze7ZkyLndaVa/ZqrFympMuRiGkbXs3lvG3yf8yPP/W0KTuvn8+/LenN79gFSLVS2I6GsnIpeISH3v/90iMk5EDk+8aIYRmlGjoH17yMlxv6NGpVoiI92YsnQTZz31P577YjEXH96GCbefaIolBIl4nqJpudyjqm+IyPHA6cBjwLPAUbEXbxiVZ9Qo6N8fdu5068uXu3WAfv1SJ5eRHmwvKeXhD+bzyrfLadO4NiOvPYrjOzdNtVhpS+jnqWlM8W6iGSVU5v2eDTyrqm8DMceZFpG2IvK5iMwTkTkicquX3kREPhGRH73fxn7H3CUii0RkgYicHqsMRmYyePC+B8HHzp0u3ajeTFywnl898QUjJy/nmuM68PHtJ5hiiUCo5wlatY4l32haLqtF5N/AqcDDIlKT6JRSJEqBP6rq91632zQR+QS4CvhUVR8SkUHAIGCgiHQDLgW6A62ACSLSRVXLQuRvZCkrVlQu3ch+Nu/Yw/3j5zLuh9V0bl6PMTccS+/CxpEPNMI8N3kxNSKiURK/Bj4CzlDVLUAT4M+xFAqgqmtV9XvvfzEwD2gN9AVGeLuNAM73/vcFRqtqiaouBRYBR8Yqh5F5tGtXuXQje1FVxs9cw6lPfME7M9bwh5MPZPwtx5tiqQShn5u9e2LJNxrl0hJ4T1V/FJGTgEuAKbEUGoiItAcOAyYDLVR1LTgFBDT3dmsNrPQ7bJWXFiy//iIyVUSmFhUVxVNUIw0YOhTqBIx5q1PHpRvVh3XbdnP9K9O4avA65j35C5Y8dCb/6H8QY/5rEYwrQ6jnCdasjiXfaJTLWKBMRA4EhgMdgFdjKdQfEannlXGbqm4Lt2uQNA22o6oOU9U+qtqnWTObMS7b6NcPhg2DwkIQcb/Dhpkxv7qgqvz3uxWc+sQXvDuuBsWfHMquzbVQlZ+N0eY9GD2hnifYsCmWfKNRLuWqWgpcCPxdVW/HtWZiRkTycIpllKqO85LXiUhLb3tLYL2Xvgpo63d4G2BNPOQwMo9+/WDZMigvd7+mWKoHKzbu5LLhkxk4dhYHt2xAzrSe7Cmp+Boz547Kk4jnKRrlsldEfgtcAYz30vJiLVhczIXhwDxVfcJv0zvAld7/K4G3/dIvFZGaItIB6Eycu+cMw0hPysqV4V8u5fS/T2LGyq08cH4PRl93NGtXB3+FmXNH6onGW+xq4AZgqKou9V7sI+NQ9nHA5cAsEZnupf0FeAh4XUSuBVbgbDyo6hwReR2Yi/M0u8k8xQwj+1m4rpg7x8xk+sotnNy1OQ+c34NWjWoDzhi9fPn+x5hzR+oR1aBmi4o7ieQDXbzVBaq6N6FSxZE+ffro1KlTUy2GYRiVZE9pOc99sZh/fPYj9WrWYMh53Tnv0FYVAk0GDgAEZ4w2G1zsiMg0Ve1T1eMjtlw8D7ERwDKcUb2tiFypqpOqWqhhGEY4Zq7awp1jZjL/p2LOPbQVQ87tRkG9/QNN+hTI4MGuK6xdO+f9ZIol9UTTLfY48CtVXQAgIl2A14DeiRTMMIzqx649ZTw5YSEv/G8JzerX5Pkr+nBatxZhj+nXz5RJOhKNQT/Pp1gAVHUhcTDoG4Zh+PPN4o2c+dQkhk1awm+OaMcnd5wYUbFkG7EEkEy3YK7RtFymishw4BVvvR8wLXEiGYZRndi2ey8PfTCfVyevoLCgDq9edxTHdqp+8cBiCciajsFcIxr0vVhiNwHH42wuk4BnVLUk8eLFjhn0DSN9+Wz+Ov4ybjbri3dz7fEduOO0g6idXz1H2LdvH9zzrbDQjT1J1LGhiNWgH7FbzIvl9YSqXqiqF6jqk5miWIzMIt2a9Ubi2Li9hFtH/8A1L02lYe08xt14HIPP7lZtFQvEFpA1HYO5hlQuIjJLRGaGWpIppJH9+Jr1y5eDKhbGI0tRVd6ZsYbTnpzE+7PWcuspnXn3D8fTq22jVItWZeL1URRLQNZ0DOYazuZyTtKkMKo94eZoMU+g7OCnrbu5+61ZTJi3nkPbNuKRi3py0AH1Uy1WTMTT1jF0aPAxO9EEZI3l2IShqlm99O7dW430R0TVtVkqLiKplsyIlbKych317XLtce+HetDd7+vzkxZraVl5qsWKC4WFwe/bwsKq5TdypDtWxP2OHJm4YyPtD0zVGN69UY3Qz2TMoJ8ZJMIgaaSe5Rt3MHDsTL5dsoljOhbw0EWHUFhQN9VixY2cHKdOAhFxQSDTlWgiGyTcoG8YycDmaMkuysqV5yct4fS/T2LO6m08eOEhvHrdUVmlWCA9bR3RkIypwk25GGmBzdGSPSz4qZgLn/mKoe/P4/gDm/LJHSfy2yPbVYgJli1k6kdRMrzLooktdhwwBCj09hdAVbVj/MQwDAvjkensKS3nX58v4pmJi2hQK49//PYwzunZMiuVio9MjW2WjGjS0YzQHw7cjhuVbyHuDcPYj+krt3DnmBksXLed83u14t5zu9Okbn6qxUoKmfhRlAzvsmiUy1ZV/SB+RRqGkS3s2lPG4x8v4MWvltKiQS1evKoPJ3etXvHAMpFktLiiUS6fi8ijwDjg55H5qvp9/MQwDCPT+HrRBgaNm8WKTTvpd1Q7Bp3Zlfq1LKZtppDoFlc0yuUo79ffJU2Bk+MvjmEY6c7WXXt58P15jP5uJe0L6jC6/9Ec3bEg1WIZaUZE5aKqv0yGIIZhpD+fzF3H3W/Noqi4hOtP7Mjtp3ahVl71jQcWD0aNyjyHgGgIF1vsMu/3jmBLPAoXkRdFZL2IzPZLGyIiq0Vkurec5bftLhFZJCILROT0eMhgGEZkNmwv4eZXv+e6l6fSuE4+b910HHedeXBMisUClWZ3TL1wLRffaKdEBv95Cfgn8HJA+pOq+ph/goh0Ay4FugOtgAki0kVVzYPNMBKEqvL29DXc9+4ctpeUcsdpXbjhxE7k14htiFw6zj+SCrI5pl5I5aKq//Z+70tU4ao6SUTaR7l7X2C0unD/S0VkEXAk8E2i5DOM6syaLbsY/OYsPl9QxGHtXKDJzi3i862ZzS/VypCOofLjRbqO0L/ZC+3/oog09tJaAyv99lnlpe2HiPQXkakiMrWoqCjRshpGVlFerrzy7XJ+9eQkvl2yiXvP6caYG46Nm2KB7H6pVoZEhI9Jl+7GdFQuzwKdgF7AWuBxLz3YMN+gUTdVdZiq9lHVPs2aNUuIkEZiSJcHo7qypGg7lz7/Lfe8NZtebRvx8e0ncM3xHcjNie8o+0yNyRVv4hk+ZtQoaNoULrusog3n6qtT8xylnXJR1XWqWqaq5cDzuK4vcC2Vtn67tgHWJFs+I3Fks3Ez3SktK+e5LxZz5lP/Y97abTxyUU9eufZI2japE/ngKpCpMbmiJdqPpHjF1PM9Oxs37r9t71649dbKnkEciBSTH2iBCwHzgbfeDbg2ljj/Afm3B2b7rbf0+387zs4CzpA/A6gJdACWALmR8rf5XDKHeM+NYUTHnNVb9eynJ2nhwPF63Yjv9Ketu5JSbixzl6RzuSNHqtapU/EerlMnsecX6tnxXyoLiZ7PRUQ+AP4DDFbVQ0WkBvCDqh4Sq2ITkdeAk4CmwDrgr956L1yX1zLgelVd6+0/GLgGKAVu0yjC0th8LplDps6NkamUlJbxz88W8ezExTSqk8f/9e3BmT0OyOpAk9HMYxIrqZibKNSz409lp+6KdT6XaJTLd6p6hIj8oKqHeWnTVbVXVQtNJqZcMgebMCx5TFu+mYFjZ7Jo/XYuPLw195zdjcZZFGgy1MDEZNxjqfhICnVePgoKYMOGyuWZjMnCdohIAZ7xXESOBrZWtUDDCEW298OnAztKSrnv3Tlc/NzX7NpTxktXH8ETv+6VdMWSSMeNcLa7ZHipxeKsUNV6Cfbs+MjPh6eeii6fuBKp3ww4HPgKp1C+AhYCPWPpi0vmYjaXzCJV/fDVgUkL1+txD32qhQPH6z1vzdLi3XtTIkeibRLhbHfJsOtV9fxirRffswOqubn7zquq9UqibS4Anp3lIJw78AJV3ZsoZRdvrFvMqO5s3bmXoe/P5fWpq+jYrC4PX9STI9o3SZk8ie6aCtct9coribe5QNXihaVbt3AybC4XBkneCsxS1fVVLThZmHIxqjMfzv6Je96ezaYde7j+hI7cckrnlAeaTLRNItJLOl0DRaabQ0usyiWakPvXAscAn3vrJwHfAl1E5P9U9ZWqFm4YRmIoKi7hr+/M5v1ZP9GtZQP+c9UR9GjdMNViAYmfYjfSLIvpOnNkMqYeTibRGPTLgYNV9SJVvQg3zqUEN8/LwEQKZxhG5VBVxk5bxalPfMGEeev58+kH8fbNx6WNYoHEO27Ea2Bissk2h5ZoWi7tVXWd3/p6oIuqbhKRjLG9GEa2s2rzTv7y5mwmLSyid2FjHr6oJwc2r5dqsfYjGVPspmvrJBzJqJdkEo3N5RmgHfCGl3QRLhTLn4HxmuaTiZnNxch2ysuVkZOX8/AH81Fg4BldufzoQnLiHA/MqF4kw+ZyE06hHIfzFnsZGOu5qqW1YjGMbGdx0XYGjZ3Jd8s2c0KXZvztgh60aZyYeGCGURmimeZYgTHeYhhGGrC3rJzn/7eEv0/4kdp5uTx2yaFcdHjrrA7dYmQWEZWL54r8MNAc13IRnM5pkGDZDMMIwuzVWxk4diZz1mzjzB4HcF/f7jSvXyvVYhlGBaLxFnsEOE9VG6pqA1Wtb4rFMJLP7r1lPPLhfPr+6yvWbSvhucsO59nLeu+nWGxOHCMdiMbmsk5V5yVcEsMwQjJ12SbuHDuTJUU7uKR3G+4+uxsN6+Ttt5/NTW+kC9F4iz0FHAC8hRvfAoCqjkuoZHHCvMWMTGZHSSmPfDifl79dTquGtXnwwkM4oUvo2VXTLYSIkbkkw1usAbAT+JVfmgIZoVwMI1OZtLCIu8bNYs3WXVx5THv+fPpB1K0Z/pG1uemNdCEab7GrkyGIYWQTN97oRoWXle1Ly811XVTPPBP+2C079/DAe/MYM20VnZrVZcwNx9C7MLpAk9kWQsTIXKLxFquFiy/WHfjZcqiq1yRQLsPIWG68EZ59dv/0srJ96aEUzAez1nLP23PYsnMPN//yQG4++cBKBZqMFFfLMJJFNN5ir+BsLqcDXwBtgOJECmUYmcywYZXfvn7bbm54ZRoDRn3PAQ1r8vbNx/Gn0w+qdATjaOJqmTeZkQyiMej/oKqHichMVe0pInnAR6p6csyFi7wInAOsV9UeXloT4L9Ae2AZ8GtV3extuwvXiioDblHVjyKVYQZ9I9lEM47R99ipKm9MW8UD4+eyu7Sc20/twnW/6ECN3Gi++ypPMuaQN7KDZExz7AtOuUVEegANcS/+ePAScEZA2iDgU1XtDHzqrSMi3YBLcd1zZwDPiEhqJ6YwDD98LYJI5Hp37cpNO7nixSncOWYmXQ9owIe3/oIBJ3VKmGIBFxTRX7GAWx88OGFFVntuvBFq1HAfHTVquPXqQDR38TARaQzcA7wDzMUNrIwZVZ0EbApI7guM8P6PAM73Sx+tqiWquhRYBBwZDzkMI1b8522PxHXXKf/5aimn/30S3y/fzP19uzO6/9F0bLYvgnGiuq7Mmyy5+OxvPscOn92tOiiYqKY5TqgAIu1x0ZV93WJbVLWR3/bNqtpYRP4JfKuqI7304cAHqrpfzDMR6Q/0B2jXrl3v5dE88YYRA6HGl/iTmwu/uXwPu4+cyrTlmzmxSzP+duEhtG5Uu8J+iey6snEwyaVGjYoegz5yc6G0NPnyVIaEd4uJSE0R+Z2I/EVE7vUtVS0wBoL1ZAfVjKo6TFX7qGqfZs1CDzgzjHgR7su/sBD2lJbz949/5LtWn7K4aDtP/PpQXrr6iP0UC1S+62rUKGja1HW7iLj/oVo62TYhVboTTLGES88mohlE+TawFZiG3wj9BLJORFqq6loRaYmbnAzcHDJt/fZrA6xJgjyGEZFQ40sAVqxQzvvnV8xbu42ze7ZkyLndaVa/Zsi8KtN1NWoUXH017PWbtm/jRrjGGygQ2NLJtgmp0p3c3NAtl2wnGptLG1X9jao+oqqP+5YEyvQOcKX3/0qccvOlX+q1pDoAnYEpCZTDqEbEauMYOjS0l1hu/V1s3F7Cvy/vzb9+d3hYxQKhBzz6p/vkveyyiorFx549oVs6/fq5LrDycvdriiVx+OK6RZueVahq2AUYBhwSab+qLMBrwFqcR9oqnJtxAc5L7Efvt4nf/oOBxcAC4Mxoyujdu7caRjhGjlStU0fVOQi7pU4dl14ZBgxQFamYj9TYq+fcsly37NwTUz7+8gSTN9giUjn5jcQwYIBqbq67Jrm5bj0TAKZqDO/3kAZ9EZmFs2nUwLUSluC6xXzzufRMhLKLNzbOxYhEPI3cw18q5Y93lrO1KI+ajXYz8J693HdH9DNUBDPmi8ANN+wb1R+N8wCYkd6IjUQGrjynqpkaRiYRL/fcz+evZ/jaWTS+djd3HNuBP53ehTr5+xvswxHMmK8K779fObny881Ib6SWkMpFVZcDiMjRwBxVLfbW6wPdAPPvNbKCWIM9btqxh/vHz+XNH1bTuXk9xg44lsPbNa6SLNEounDOAwC1asELL5gtxUgt0Rj0nwW2+63v8NIMIyuoqnuuqjJ+5hpOe+IL3p2xhltO6cz4W46vsmKB6Iz5weT1Z/du+OqrKotgGHEhGuUi6meYUdVyonNhNoyMIJpgj4Gs27ab/q9M4+ZXf6BVo9q8+4fjueO0LtSsEZuPaTSKzl/eUEQKnmkYiSYa5bJERG4RkTxvuRVn3DeMpJHoSL7RuueqKv/9bgWnPvEFkxYW8ZezuvLmjcdycMt9RvtYZI1W0fnkDUV1GKRnpDfRREVuDjwNnIzzHvsUuE1V14c9ME0wb7HMJ10i+a7YuJNB42by9eKNHNWhCQ9f1JP2TeumVNZMDi9ipDcJD/+iqutV9VJVba6qLVT1d5miWIzsINWRfMvKleFfukCTM1dtZegFPXjtuqP3UyyxyFrV1k61HqRnpDWJi+1tGHEiVlfhcC9u/21Nm7rFf7+F64q56NmvuX/8XFqs78yW/5zG5ccU0rGjBFUAVZH1xhvh8sudB5iq++3fPzoF88wzMGDAvnAiubluPdJUyoaRaFIeFTnRWLdY5hPLIMdw3VSw/zZ/8mqW0/j0GbTqXcQva/Th30Mbs3On7JePf3dXZWUdNcoplmCPoQ2CNFJJrN1icQ/pkm6LhX/JfGIJz1JYGDw0SmFh6G3+S/2mJbqheHfYfCor68iR7jiRfWFBwoVwKSysfCgaw4gVYgz/EtKlWETuiKCUnqiyRjOMShBLJN9Q3VHRTvGzfWM+H74dLuJx5WQNbElF8ury7ybzz98w0p1wscX+6v09CDgCF5UY4Fxgkqr+PvHixY51i1VvwsXhEgneHeVPQQHs2hW666ygAOrVi17pRRsXLBjWTWYkk4R5i6nqfap6H9AUOFxV/6iqfwR64+ZSMYwqk+hxKz7CjWZXBZHQ2sV3XCjFkp8P27btb4i/8cbQ5xbLdMI2FbGRSUTjLdYO2OO3vgdonxBpjGqB/3zzlfWOqiy+QYmhUIXcBjtBlIICpaCg4uDFTZtCH1u//v5zqezcCc89F/rcQoV3yc3dV25BQfB9oo11ZhjpQDTK5RVgiogM8brKJgMvJ1YsI5tJ9riVfv1Ch0qp1biEabP3oOXChg3Chg0VR+mHeqEXFoZWPIFdbf7nFiq8y4gR+8p96imbitjIfKIZRDkUuBrYDGwBrlbVvyVYLiMDibarK14h7isjz/btkJdX8a2fV7Oc557K59C2jULmES7WV2VaEr5ziya8S1VinRlG2hGNSxlwPE6pADQDOsTiopbMxVyRk0Nl3IWjdeuNtzw5NcpUau1WKNdWbcqidu/1dx32dwuOdkbIeJ+bYSQDYnRFjkax/BV4F1jorbcCvoql0GQuplySQ2UURrymFfa99H3Tx/rK808PXJq02KOlZeUh86rsuJJgUxIHLlU5N8NINclQLtNxUxv/4Jc2M5ZCoxIMlgGzvPKnemlNgE+AH73fxpHyMeWSHEK9YEPN417Vl7n/8aFaDeFaE8HkCZZXXp5qQUFk+UIpsdzcxAyAjLXeDCNakqFcpni/33u/dZOoXJoGpD0CDPL+DwIejpSPKZfkkIyurmjK+7kLLKc8anmiGakfqvVRWaUaC/Fq8RlGNMSqXKLxFntdRP4NNBKR64AJwAvR2nTiTF9ghPd/BHB+iuQwAqjqbI5VJZLxv7wccvMrDn8PJU80jgShvNmimTkyXqQ6OrRhVIZovMUeA8YAY3Gj9e9V1acTLRigwMciMk1EfAHEW6jqWk+utUDzYAeKSH8RmSoiU4uKipIgqpFsD6dIL++cHBjxYk5U8kSrCIIpoWQq1WR52RlGXIjUtCFI11OwtHgvQCvvtzkwAzgB2BKwz+ZI+Vi3WGpJlI0gGk+taOQZMMDZVqL1+Ap2PsmygyS769Go3pAEm8v3QdISbnMJKG8I8CdgAdDSS2sJLIh0rCmX1JFoG8GLL5WqVMK2Eo1nF6jWrauan7+/3AMGpNbmEc/6NMcAIxIJUy7AAJy31k5gpt+yFBgVS6ERhXJOA/X9/n8NnAE8SkWD/iOR8jLlkjoS+aX91Y9F+ouHP9OCc77XGjXLIr5wR46MTrGEa6GkQ8shHkrBHAOMaIhVuYSLitwQaAw86L3IfRSrapiIS7EjIh2BN73VGsCrqjpURAqA13HxzlYAl0SSxaIip46cHPfqCkTEGdyrwtZde3nw/XmM/m4l7Qvq8NBFPVn8TUHEcPyVjUYcTO5EnE8qiGXyNaP6EGtU5IgzUYrI0cAcVS321usD3VR1clULTSamXFJHvF9in8xdx91vzaKouITrftGR20/rQq283KiODaUYQhFs32x5KWeLkjQSS8JC7vvxLLDdb32Hl2YYYQnnSVWZkPsbtpdw86vfc93LU2lcJ5+3bjqOu846mFp5uVHnEw/X4GS7WyeKZLpPG9WYSP1mwPQgaUk16MeymM0ltYTyrgrs8xdxBnN/ysvL9c3vV2mv+z7Szn95X5+esFD3lJZVyDta20Fl4oDl5lbufDINs7kY0UASvMXGAbcAed5yK/BWLIUmczHlkn6EMoyL7HvBrd68U696cbIWDhyv5//rS13407ao8wllYPdXDOGUS6CSy0ayQUkaiSVW5RKNzaU58DRwMm5g46fAbaq6PiFNqThjNpfUM2pUxTnlwxnWmzRRJL+MjT/lUqPhbq66pZjnhjQjN0f2yyvcrRvhtg5pP6lXD4qLI5+TYWQ7Cbe5qOp6Vb1UVZuragtV/V2mKBYjsURj7wg266RI6Dw3bYKNP9UAhNKttXn54eaMfk2C5hUOkX1L69b7bw9lP3nuufD5xko8pndO1hTRhhEToZo0wJ3e7z9wLZcKSyzNpWQu1i2WGKLtt48mKGSkpaAg9rxatQp+DsnsGoqHrcPsJUayIIHjXM5V1XdF5MoQSmlEsPR0w7rFEkO0brmVcwFW3OwOQbZo5d2Jg+WRSirjyhzYlegbu5Mt7tBG+hNrt1iNUBtU9V3vNyOUiJFcog2i2KQJbNwYKTelZm2lZFeY/jIi22vSnWjrzNf954uAvHy5W69MHoaRakIqFxF5F/cpGRRVPS8hEhkZQagXfdXGSkhExTJqlPt693/p+qhRA0pLq1Jucom2zsKF1o9vvRtG4ghn0H8MeBwXS2wX8Ly3bAdmJ140I52JdkDhpjgFCho82HULXXnl/g4BIlBQ4H5zQwzYb9UqPnLEQrR1Fq51ki0DOY1qQCSjDDApmrR0XcygnziiMYhHG84+0uKb2TGasS2tWkU25qeKaOos0jlm+hiVTJe/ukASBlHOAzr6rXcA5sVSaDIXUy6ppUlB8JD4lV18L9ZwAyCz5SWVzR5h2Xxu2UasyiWa2GK3AxNFZKKITAQ+B26LdwvKyD4+nP0TmyIa8yPj3+0TzrZw2WXQtGnmj/tI9qyeycSmaq4+RByhDyAiNYGu3up8VS1JqFRxxFyRk09RcQlD3pnDf0cLG98/FMr3/4YRCe8a7NteWFgxhH6gJ1Uw6tTJnpdxtmERmTOHhI/QF5E6wJ+Bm1V1BtBORM6paoFGduE/WrywULn1gY2c+sQXjH0jh22fBFcssL9R2p/cXPeiUXVjN/yVhO+rPhz2JZy+WETm6kM03WL/AfYAx3jrq4AHEiaRkfb4FIoIXH75vnAsK1YIT9/ThJlDTmPD+EPZW7L/7ZWTA3l5sGNH6PzLysKX36+fa9GEw+dxZaFS0gvzdqs+RKNcOqnqI8BeAFXdRahh1EZWEO6F7B/fC4J1cQgglJUFv0XKy2Hv3vDlR1IcEPwl5U+7dsHjmvXvbwomlWSzPckIIJLFHzd/fW3ge2+9EzAlFi+CZC7V3Vussm6fkbx54uVaHGqpjOfQyJHB5fHlkQ5z3htGpkISXJFPA74AioBRwDLgpFgKjUlgOANYACwCBkXaP5uUS2UURagXL7j0UMeGeiHXq6eakxOb4og0j0pVxzyEqpdQ5fnGzBiGEZqEKhdct9mvgQLgbOAcoGksBcYkLOQCi4GOQD4wA+gW7phsUS7xnnUx1LGRFEBll9zcyIolUeMcrOViGFUnVuUS1uaiquU4L7GNqvqeqo5X1Q2xd8ZVmSOBRaq6RFX3AKOBvimUJ2lUZnxAsH0DCXVsvL12Roxw/eru22B/EtnnbsZjw0gd0Rj0PxGRP4lIWxFp4lsSLllwWgMr/dZXeWkVEJH+IjJVRKYWFRUlTbhEUplouNFGyA22XyRDeTBCTf5VUOCURih5RPZ3NY4nZjw2jNQRjXK5BrgJmARM85ZUjUoM9hrb75tYVYepah9V7dOsWbMkiJV4KjM+INrWR7D9Kr6QlSDVW4E6deCGG4K3EJ56Krw8yRjb0K+fU2Dl5YlVZIZhVCSaaY47BFk6JkO4IKwC2vqttwHWpEiWpFKZLp5oWh/huof69YMRHxdxzN8+J7fBrpB51K3rFNEzz4RvIaRz95SNgzGMBBHJKAPUAu4AxgFjcXHFasVi6Knqgpt/ZgkueKbPoN893DHZYtBXrby3mP++AwbsM3D7jOzB8ti8o0Rv/+8PWjhwvJ782Of6f08WB3UOOOWUxMmeLCyIomGEhiS4Ir8ODAd+6S3DgDdiKTQmgeEsYCHOa2xwpP2zSbn4E+hqHM692P+YcC/T92au0d73f6yd7npPH/1wvu7aU/rzcemmGOKBeZMZRmhiVS4RA1eKyAxVPTRSWrqSjYErR42CK67YP9Bffj68+GJou0Ko+dfbtC3n7KE/8OGcn+jRugEPX9ST7q0axl3udMOCKBpGaBIeuBL4QUSO9ivwKOCrqhZoVB2ffeCyy4K//PbsCR+wMZTX1qqVwmcL1jPwjK68deNx1UKxgAVRNIxEEo1yOQr4WkSWicgy4BvgRBGZJSIzEyqd8TOBMb1CEc4NOdRLs06TEj689RcMOKkTNXKjuSWyg3R2NDCMTKdGFPuckXApjIhEMzASwn91Dx0K/fsrO3fu8+jOr1XOv5+qScdmteIgZWbh6z4cPNgp5XbtKs4dYxhG1YmoXFQ1wreykQyiHRgZ7qv7qNOK6fbrtfwwrg1l22rTuo3y8EM51fpl2q+fKRPDSATRtFyMNKBdu8hdYgMGBH9R7i0r599fLObpTxdRp0Mub0ysw/m9WiNSfbrADMNILqZcMgTXpVWxayzUVMD+zFq1lT+PmcH8n4o5p2dLhpzXnab1aiZPcMMwqiWmXDKEytoHdu8t48kJC3nhf0spqJvPsMt786vuByRPYMMwqjWmXDKIaO0Dk5dsZNC4WSzdsINLj2jLXWcdTMPaeYkX0DAMw8OUSxZRvHsvD384n5HfrqBtk9qM+v1RHHdg01SLZRhGNcSUS5bw+fz1DH5zFmu37eba4zvwx191oU6+XV7DMFKDvX0ynE079nD/+Lm8+cNqOjevx9gBx3J4u8apFsswjGqOKZcMRVV5b9Za/vr2HLbu2sstp3Tmpl92omaN3FSLZhiGYcolE1m3bTd3vzWbT+auo2ebhoz8/VEc3LJBqsUyDMP4GVMuGYSq8vrUlTzw3jz2lJYz+KyDufq49tUqHphhGJmBvZUyhBUbd9LvhckMHDuLbi0b8NFtJ3DdCR2jUiw226JhGMnGWi5pTlm58tLXy3jsowXk5ghDL+jBb49oR06ORD6YfdGUfSP7ly9362AxtQzDSBwRJwvLdDJ5srCF64q5c8xMpq/cwsldmzP0gh60bFi7UnmEmiCssBCWLYuLmIZhZCGxThZmLZc0ZE9pOc9OXMw/P/+R+rXyeOrSXpx3aCtEomut+BMqmnK0UZYNwzCqQtrZXERkiIisFpHp3nKW37a7RGSRiCwQkdNTKWeimLFyC+f+40uenLCQM3u05JPbT6Bvr9ZVUixgsy0ahpEa0rXl8qSqPuafICLdgEuB7kArYIKIdFHVslQIGG927SnjiU8WMPzLpTSvX4sXrujDqd1axJxvsGjKNtuiYRiJJl2VSzD6AqNVtQRYKiKLgCNx0y5nNN8s3sigcTNZvnEnvzuqHYPO7EqDWvEJNGmzLRqGkQrSVbncLCJXAFOBP6rqZqA18K3fPqu8tIxl2+69PPj+fF6bsoLCgjq8et1RHNsp/oEmbbZFwzCSTUqUi4hMAIJNLjIYeBa4H1Dv93HgGiCY0SGoq5uI9Af6A7RLU+PCp/PWMfjN2awv3k3/Ezpy+6ldqJ1voVsMw8gOUqJcVPXUaPYTkeeB8d7qKqCt3+Y2wJoQ+Q8DhoFzRa66pPFn4/YS7nt3Lu/MWMNBLerz3OW96dW2UarFMgzDiCtp1y0mIi1Vda23egEw2/v/DvCqiDyBM+h3BqakQMQqoaq8M2MN9707l+Lde7n91C4MOKkT+TXSzmHPMAwjZtJOuQCPiEgvXJfXMuB6AFWdIyKvA3OBUuCmTPEUW7t1F3e/OZtP56/n0LaNeOSinhx0QP1Ui2UYhpEw0k65qOrlYbYNBTLGiba8XHntuxU8+P58SsvLufvsg7n6uA7kRhm6xTAMI1NJO+WSLSzbsINB42by7ZJNHNupgIcu7Em7gjqpFsswDCMpmHKJM6Vl5bz41VIe/3gh+bk5PHThIfzmiLZVHmFvGIaRiZhyiSPzf9rGwDEzmbFqK6ce3IIHzu/BAQ1rpVoswzCMpGPKJQ6UlJbxr88X88zni2hYO49//u4wzj6kpbVWDMOotphyiZEfVmzmzjEz+XH9di44rDX3ntONxnXzUy2WYRhGSjHlUkV27inl8Y8X8uJXSzmgQS3+c9UR/LJr81SLZRiGkRaYcqkCXy3awKBxM1m5aReXHd2OgWd0pX6cAk0ahmFkA6ZcKsHWXXt58P15jP5uJR2a1uW//Y/mqI4FqRbLMAwj7TDlEiUfz/mJu9+azYbtJVx/ogs0WSvPAk0ahmEEw5RLBDZsL2HIO3MYP3MtXQ+ozwtX9qFnm0apFsswDCOtMeUSAlXlremrue/duewsKeOPp3XhhpM6kZdrgSYNwzAiYcolCKu37GLwm7OYuKCIw9q5QJOdW1igScMwjGgx5eJHebkyasoKHnp/HuUK957TjSuPbW+BJg3DMCqJKRePJUXbGTR2FlOWbeL4A5vy4IWH0LaJBZo0DMOoCtVeuZSWlfPCl0t58pOF1KyRwyMX9+SS3m0sdIthGEYMVGvlMnfNNu4cO4PZq7dxevcW3N+3B80bWKBJwzCMWKmWymX33jL++dkinvtiMY3q5PFMv8M565CWqRbLMAwja6h2ymXa8k3cOWYmi4t2cNHhbbjnnINpVMcCTRqGYcSTaqNcdpSU8uhHCxjxzTJaNazNiGuO5MQuzVItlmEYRlaSkhGBInKJiMwRkXIR6ROw7S4RWSQiC0TkdL/03iIyy9v2tFTC4v6/H4s4/e+TeOnrZVxxdCEf3X6CKRbDMIwEkqrh5rOBC4FJ/oki0g24FOgOnAE8IyK+AF7PAv2Bzt5yRjQFrdq8i8uHTyE/N4c3bjiG+/r2oF7NatNgMwzDSAkpecuq6jwgmLtvX2C0qpYAS0VkEXCkiCwDGqjqN95xLwPnAx9EKmvzzj3cf1InbjmlswWaNAzDSBLp9gnfGvjWb32Vl7bX+x+YHhQR6Y9r5QCUDDzz4NkD4yxoAmgKbEi1EBHIBBnB5Iw3Jmd8yRQ5D4rl4IQpFxGZABwQZNNgVX071GFB0jRMelBUdRgwzJNjqqr2CbVvupAJcmaCjGByxhuTM75kkpyxHJ8w5aKqp1bhsFVAW7/1NsAaL71NkHTDMAwjDUm3+PHvAJeKSE0R6YAz3E9R1bVAsYgc7XmJXQGEav0YhmEYKSZVrsgXiMgq4BjgPRH5CEBV5wCvA3OBD4GbVLXMO2wA8AKwCFhMFMZ8j2HxlD2BZIKcmSAjmJzxxuSML9VCTlENabowDMMwjCqRbt1ihmEYRhZgysUwDMOIO1mjXJIdUiZOMg8RkdUiMt1bzookc6oQkTM8WRaJyKBUy+OPiCzzruN0n/ukiDQRkU9E5Efvt3EK5HpRRNaLyGy/tJBypeqah5Azre5NEWkrIp+LyDzvOb/VS0+r+gwjZ7rVZy0RmSIiMzw57/PS41efqpoVC3AwbtDPRKCPX3o3YAZQE+iAcwbI9bZNwTkVCM5B4MwkyzwE+FOQ9JAyp6hucz0ZOgL5nmzdUn3N/eRbBjQNSHsEGOT9HwQ8nAK5TgAOB2ZHkiuV1zyEnGl1bwItgcO9//WBhZ4saVWfYeRMt/oUoJ73Pw+YDBwdz/rMmpaLqs5T1QVBNv0cUkZVl+K8zY4UkZZ4IWXU1Z4vpEw6EFTmFMpzJLBIVZeo6h5gtCdjOtMXGOH9H0EKrq2qTgI2BSSHkitl1zyEnKFIiZyqulZVv/f+FwPzcFE60qo+w8gZilTJqaq63VvN8xYljvWZNcolDK2BlX7rvtAxralESJkEcrOIzPS6JnxN0FAyp4p0kycQBT4WkWle6B+AFurGR+H9Nk+ZdBUJJVc61nFa3psi0h44DPe1nbb1GSAnpFl9ikiuiEwH1gOfqGpc6zOjlIuITBCR2UGWcF/RcQkpU1UiyPws0AnoBawFHo8gc6pIN3kCOU5VDwfOBG4SkRNSLVAVSLc6Tst7U0TqAWOB21R1W7hdg6SlUs60q09VLVPVXriIJ0eKSI8wu1daznQLXBkWzcCQMtHKLCLPA+O91VAyp4p0k6cCqrrG+10vIm/imuvrRKSlqq71ukDXp1TIfYSSK63qWFXX+f6ny70pInm4F/YoVR3nJaddfQaTMx3r04eqbhGRibhpTOJWnxnVcqkiaRtSxrt4Pi7AzXMTUuZkyhbAd0BnEekgIvm4OXfeSaE8PyMidUWkvu8/8CtcPb4DXOntdiXpEy4olFxpdc3T7d70ntHhwDxVfcJvU1rVZyg507A+m4lII+9/beBUYD7xrM9EeyUka8FdsFVACbAO+Mhv22Ccd8MC/DzCgD64i7wY+CdexIIkyvwKMAuY6V28lpFkTmH9noXzfFmMi2yd8mvuydUR58UyA5jjkw0oAD4FfvR+m6RAttdwXSC+KSOuDSdXqq55CDnT6t4Ejsd1w8wEpnvLWelWn2HkTLf67An84MkzG7jXS49bfVr4F8MwDCPuVIduMcMwDCPJmHIxDMMw4o4pF8MwDCPumHIxDMMw4o4pF8MwDCPumHIxshIROUlEjo0xj+2R9/p535dE5OJYyosXIvJ1JfdPG9mN7MGUi5GtnATEpFwyFVWtludtpBemXIyMQUTe8oJTzvELUOmba+Z7b26KT72AgTcAt3tzZ/wi8Ovc1yoRkXreMd+LmxMmYrRnEbnCC0A4Q0Re8dt0goh8LSJLfGWFyl9E2oub8+N573w+9kZKIyJHePl/IyKPijfPihdo8FER+c7bfn0I+XzndpKITBSRMSIyX0RGeSPIw53bKSLygyfriyJS00t/SETmeuU+5qVdIi5O3gwRmRSp3oxqRrJGAdtiS6wL3mhhoDZuVHEB0AwXrbVDwD5D8Js/A3gJuNhvfbv3WwM39QJAU1wocfHfJ0CG7rgRyk0DynsJeAP3wdYNN0VByPyB9kAp0Mvb9jpwmfd/NnCs9/8hvHlWgP7A3d7/msBU33kHyOg7t5OArbg4UDnAN8DxQfZ/CbgYqOXVZRcv/WXgNqCJd86+emnk/c4CWvun2WKLb7GWi5FJ3CIiM4BvcUH0OuMmOJqkbo4JVDXaeUl8CPA3EZkJTMCFEW8RZv+TgTGquiFIeW+parmqzvXLI1z+S1V1uvd/GtDei/dUX1V9dpNX/fL/FXCFuDDpk3HKtXOE85uiqqtUtRwXiqR9mH0P8mRa6K2PwE0ktg3YDbwgIhcCO73tXwEvich1uAnlDONnMioqslF9EZGTcMH1jlHVnV4U11q4l3c0MYxK8bqBva6hfC+9H67101tV94rIMi/fkKKEKa8kYL9I+fvvX4ZrkYXrthLgD6r6UZh9wslURvhnPmjZqloqIkcCp+CClt4MnKyqN4jIUcDZwHQR6aWqGyshm5HFWMvFyBQaAps9xdIV12IB19VzohepFRFp4qUX46aZ9bEM6O3974ubec+X73rvxf9LoDCCHJ8CvxaRgoDywskddf6quhkvWreXdKnf5o+AAeJCuiMiXbxI0PFiPq71dKC3fjnwhbi5SRqq6vu4brJeXvmdVHWyqt4LbKBiSHajmmMtFyNT+BC4weteWoDrGkNVizzj/jgRycHNP3Ea8C4wxjOg/wF4HnhbRKbgFMQOL99RwLsiMhXXbTQ/nBCqOkdEhuJeumW4yLJXhTmkUvl7XAs8LyI7gIk4uwnAC7hure+91lcRcZy+WVV3i8jVwBsiUgM31cJzOJvL2yLiayne7h3yqIh09tI+xUWmNgwAi4psGOmGiNRTb35zERmEC89+a4rFMoxKYS0Xw0g/zhaRu3DP53LCt4wMIy2xlothGIYRd8ygbxiGYcQdUy6GYRhG3DHlYhiGYcQdUy6GYRhG3DHlYhiGYcSd/wdsIVdsmGUmbQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "left_lim_x = -100\n",
    "right_lim_x = 300\n",
    "low_lim_y = -100\n",
    "up_lim_y = 300\n",
    "\n",
    "x = np.linspace(left_lim_x, right_lim_x)\n",
    "# x = np.linspace(-0.2, 0.15)\n",
    "plt.plot(x, x)\n",
    "plt.plot(np.array(acctual_influence_2) - np.array(acctual_influence_1) + np.array(actual_influence_node_features), \n",
    "         np.array(predict_influence_2) - np.array(predict_influence_1) + np.array(predict_influence_node_features), 'o', color='blue')\n",
    "plt.xlabel('actual change in loss')\n",
    "plt.ylabel('predicted change in loss')\n",
    "plt.title('Influence function of completely removing one node Cora')\n",
    "plt.ylim(low_lim_y, up_lim_y)\n",
    "plt.xlim(left_lim_x, right_lim_x)\n",
    "# plt.title('Influence function on Iris dataset')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "315f98be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=0.7485425641249919, pvalue=2.1443880954652013e-26)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(np.array(acctual_influence_2) - np.array(acctual_influence_1) + np.array(actual_influence_node_features), \n",
    "         np.array(predict_influence_2) - np.array(predict_influence_1) + np.array(predict_influence_node_features))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8a8df7a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4b803e8f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "949c0219",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a7dffee",
   "metadata": {},
   "outputs": [],
   "source": [
    "node_id"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4496f268",
   "metadata": {},
   "outputs": [],
   "source": [
    "extra_index_train "
   ]
  }
 ],
 "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
}
