{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "69ac45ac",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n",
      "Intel(R) Extension for Scikit-learn* enabled (https://github.com/intel/scikit-learn-intelex)\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "import torch\n",
    "import dgl\n",
    "import numpy_ml\n",
    "import scipy\n",
    "import cupy as cp\n",
    "import cupyx\n",
    "\n",
    "from dgl import function as fn\n",
    "from dgl.base import DGLError\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "from scipy.special import softmax, log_softmax\n",
    "from numpy.linalg import inv, pinv\n",
    "from sklearn.preprocessing import OneHotEncoder\n",
    "from sklearn.metrics import log_loss\n",
    "from dataset import load_graph_dataset\n",
    "\n",
    "from model_node_influence import NodeInfluenceSGC\n",
    "\n",
    "from model_softmax import SimplifiedGraphNeuralNetwork, fast_hess, fast_hess_cuda, fast_get_inv_hvp_cuda\n",
    "\n",
    "from matplotlib import pyplot as plt\n",
    "from scipy.linalg import cho_solve, cho_factor\n",
    "from model_edge_influence import EdgeInfluenceSGC, generate_remove_index_train\n",
    "from tqdm import tqdm\n",
    "\n",
    "from sklearnex import patch_sklearn, config_context\n",
    "patch_sklearn()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2c56273d",
   "metadata": {},
   "outputs": [],
   "source": [
    "data_set = 'cora'\n",
    "# l2_term = 0.01\n",
    "l2_term = 0.01\n",
    "# batch_edges = 1\n",
    "num_layer = 2\n",
    "\n",
    "# data_set = 'pubmed'\n",
    "# l2_term = 0.004\n",
    "# num_layer = 2\n",
    "\n",
    "# data_set = 'citeseer'\n",
    "# l2_term = 0.003\n",
    "# num_layer = 2\n",
    "\n",
    "# data_set = 'reddit'\n",
    "# l2_term = 0.99\n",
    "# num_layer = 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26e7abb5",
   "metadata": {},
   "source": [
    "##### 1, load data, convert to one hot encoding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "09bf83b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"retrieve all edges connected to traing nodes\"\"\"\n",
    "def generate_remove_index_train_all(from_indexes, to_indexes, train_mask):\n",
    "    train_index = torch.where(train_mask == 1)[0]\n",
    "    remove_from_list = []\n",
    "    remove_to_list = []\n",
    "    for i in tqdm(range(len(train_index))):\n",
    "        f_index = train_index[i]\n",
    "        to_index_list = torch.where(from_indexes == f_index)[0]\n",
    "        for to_index_e in to_index_list:\n",
    "            j = to_index_e\n",
    "            t_index = to_indexes[j]\n",
    "\n",
    "            remove_from_list.append(f_index)\n",
    "            remove_to_list.append(t_index)\n",
    "\n",
    "    return torch.tensor(remove_from_list), torch.tensor(remove_to_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "84853f84",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset(data_set)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7b96a88b",
   "metadata": {},
   "outputs": [],
   "source": [
    "feat0 = feat.clone()\n",
    "degs = graph.in_degrees().float().clamp(min = 1)\n",
    "norm = torch.pow(degs, -0.5)\n",
    "norm = norm.to(feat0.device).unsqueeze(1)\n",
    "\n",
    "for _ in range(num_layer):\n",
    "    feat0 = feat0 * norm\n",
    "    graph.ndata['h'] = feat0\n",
    "    graph.update_all(fn.copy_u('h', 'm'),\n",
    "                     fn.sum('m', 'h'))\n",
    "    feat0 = graph.ndata.pop('h')\n",
    "    feat0 = feat0 * norm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "31d0f2e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "total_num_labels = np.max(labels.numpy()) + 1\n",
    "\n",
    "number_of_training_data = np.sum(train_mask.numpy())\n",
    "\n",
    "pred_infl_mat = np.zeros([number_of_training_data, total_num_labels +1])\n",
    "act_infl_mat = np.zeros([number_of_training_data, total_num_labels +1])\n",
    "\n",
    "train_node_idx = torch.where(train_mask == 1)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2153f390",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([   3,    7,   24,   34,   52,   65,   67,   69,   70,   72,   74,   79,\n",
       "         130,  138,  140,  168,  184,  186,  240,  242,  266,  310,  328,  346,\n",
       "         352,  403,  417,  419,  429,  431,  432,  452,  468,  479,  484,  501,\n",
       "         542,  554,  575,  580,  592,  602,  623,  624,  637,  645,  666,  736,\n",
       "         741,  760,  776,  812,  818,  821,  845,  850,  859,  866,  899,  910,\n",
       "         925, 1002, 1047, 1049, 1082, 1101, 1162, 1209, 1230, 1281, 1286, 1308,\n",
       "        1327, 1337, 1343, 1372, 1410, 1415, 1428, 1454, 1487, 1488, 1516, 1544,\n",
       "        1587, 1682, 1683, 1716, 1754, 1793, 1794, 1795, 1819, 1826, 1852, 1879,\n",
       "        1898, 1921, 1924, 1938, 1939, 1941, 1958, 1981, 1985, 2001, 2004, 2013,\n",
       "        2020, 2029, 2032, 2064, 2068, 2079, 2141, 2156, 2160, 2169, 2208, 2209,\n",
       "        2223, 2224, 2226, 2232, 2287, 2296, 2337, 2367, 2401, 2445, 2468, 2469,\n",
       "        2518, 2528, 2543, 2569, 2658, 2669, 2673, 2681])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_node_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "ff314e69",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████| 140/140 [00:00<00:00, 14471.67it/s]\n"
     ]
    }
   ],
   "source": [
    "from_indexes, to_indexes = graph.edges()\n",
    "\n",
    "f_l, t_l = generate_remove_index_train_all(from_indexes, to_indexes, train_mask)\n",
    "\n",
    "acctual_influence_node_features = []\n",
    "acctual_influence_edges = []\n",
    "\n",
    "predict_influence_node_features = []\n",
    "predict_influence_edges = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "79aae4f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "acctual_influence_1 = []\n",
    "acctual_influence_2 = []\n",
    "\n",
    "predict_influence_1 = []\n",
    "predict_influence_2 = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7526b99d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n"
     ]
    }
   ],
   "source": [
    "for i in range(total_num_labels):\n",
    "    print(i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "11d4588a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                   | 0/140 [00:00<?, ?it/s]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.65it/s]\u001b[A\n",
      "  1%|▎                                          | 1/140 [00:08<20:25,  8.82s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      "  1%|▌                                          | 2/140 [00:12<12:50,  5.58s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      "  2%|▉                                          | 3/140 [00:15<10:15,  4.49s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      "  3%|█▏                                         | 4/140 [00:18<09:16,  4.09s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.90it/s]\u001b[A\n",
      "  4%|█▌                                         | 5/140 [00:22<08:34,  3.81s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.95it/s]\u001b[A\n",
      "  4%|█▊                                         | 6/140 [00:25<08:17,  3.72s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.05it/s]\u001b[A\n",
      "  5%|██▏                                        | 7/140 [00:29<08:03,  3.63s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.99it/s]\u001b[A\n",
      "  6%|██▍                                        | 8/140 [00:32<07:51,  3.57s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.11it/s]\u001b[A\n",
      "  6%|██▊                                        | 9/140 [00:35<07:38,  3.50s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.08it/s]\u001b[A\n",
      "  7%|███                                       | 10/140 [00:39<07:29,  3.46s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.05it/s]\u001b[A\n",
      "  8%|███▎                                      | 11/140 [00:42<07:22,  3.43s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.03it/s]\u001b[A\n",
      "  9%|███▌                                      | 12/140 [00:45<07:12,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.06it/s]\u001b[A\n",
      "  9%|███▉                                      | 13/140 [00:49<07:07,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.07it/s]\u001b[A\n",
      " 10%|████▏                                     | 14/140 [00:52<07:08,  3.40s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.12it/s]\u001b[A\n",
      " 11%|████▌                                     | 15/140 [00:56<07:10,  3.44s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.09it/s]\u001b[A\n",
      " 11%|████▊                                     | 16/140 [00:59<07:08,  3.46s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.04it/s]\u001b[A\n",
      " 12%|█████                                     | 17/140 [01:03<06:59,  3.41s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.00it/s]\u001b[A\n",
      " 13%|█████▍                                    | 18/140 [01:06<07:00,  3.45s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.10it/s]\u001b[A\n",
      " 14%|█████▋                                    | 19/140 [01:09<06:53,  3.42s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.99it/s]\u001b[A\n",
      " 14%|██████                                    | 20/140 [01:13<06:51,  3.43s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.99it/s]\u001b[A\n",
      " 15%|██████▎                                   | 21/140 [01:16<06:44,  3.40s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.93it/s]\u001b[A\n",
      " 16%|██████▌                                   | 22/140 [01:19<06:34,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.90it/s]\u001b[A\n",
      " 16%|██████▉                                   | 23/140 [01:23<06:32,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.90it/s]\u001b[A\n",
      " 17%|███████▏                                  | 24/140 [01:26<06:26,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.93it/s]\u001b[A\n",
      " 18%|███████▌                                  | 25/140 [01:29<06:23,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      " 17%|██████▊                                  | 23/139 [00:00<00:00, 229.11it/s]\u001b[A\n",
      " 60%|████████████████████████▊                | 84/139 [00:00<00:00, 448.85it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.96it/s]\u001b[A\n",
      " 19%|███████▊                                  | 26/140 [01:33<06:14,  3.29s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.91it/s]\u001b[A\n",
      " 19%|████████                                  | 27/140 [01:36<06:12,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n",
      " 20%|████████▍                                 | 28/140 [01:39<06:12,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 21%|████████▋                                 | 29/140 [01:43<06:09,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.78it/s]\u001b[A\n",
      " 21%|█████████                                 | 30/140 [01:46<06:08,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.95it/s]\u001b[A\n",
      " 22%|█████████▎                                | 31/140 [01:49<06:06,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.96it/s]\u001b[A\n",
      " 23%|█████████▌                                | 32/140 [01:53<06:05,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.92it/s]\u001b[A\n",
      " 24%|█████████▉                                | 33/140 [01:56<05:58,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.00it/s]\u001b[A\n",
      " 24%|██████████▏                               | 34/140 [02:00<05:56,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 25%|██████████▌                               | 35/140 [02:03<05:54,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.90it/s]\u001b[A\n",
      " 26%|██████████▊                               | 36/140 [02:06<05:48,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 26%|███████████                               | 37/140 [02:10<05:47,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 27%|███████████▍                              | 38/140 [02:13<05:43,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.94it/s]\u001b[A\n",
      " 28%|███████████▋                              | 39/140 [02:16<05:38,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 29%|████████████                              | 40/140 [02:20<05:35,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.93it/s]\u001b[A\n",
      " 29%|████████████▎                             | 41/140 [02:23<05:36,  3.40s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 30%|████████████▌                             | 42/140 [02:27<05:30,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 31%|████████████▉                             | 43/140 [02:30<05:25,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 31%|█████████████▏                            | 44/140 [02:33<05:22,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.76it/s]\u001b[A\n",
      " 32%|█████████████▌                            | 45/140 [02:37<05:17,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 33%|█████████████▊                            | 46/140 [02:40<05:14,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 34%|██████████████                            | 47/140 [02:43<05:15,  3.39s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 34%|██████████████▍                           | 48/140 [02:47<05:16,  3.44s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 35%|██████████████▋                           | 49/140 [02:50<05:09,  3.40s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 36%|███████████████                           | 50/140 [02:54<05:05,  3.39s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 36%|███████████████▎                          | 51/140 [02:57<04:58,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 37%|███████████████▌                          | 52/140 [03:00<04:57,  3.39s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 38%|███████████████▉                          | 53/140 [03:04<04:53,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 39%|████████████████▏                         | 54/140 [03:07<04:51,  3.39s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.97it/s]\u001b[A\n",
      " 39%|████████████████▌                         | 55/140 [03:10<04:45,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 40%|████████████████▊                         | 56/140 [03:14<04:40,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 41%|█████████████████                         | 57/140 [03:17<04:40,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 41%|█████████████████▍                        | 58/140 [03:20<04:34,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 42%|█████████████████▋                        | 59/140 [03:24<04:33,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 43%|██████████████████                        | 60/140 [03:27<04:29,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 44%|██████████████████▎                       | 61/140 [03:31<04:26,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 44%|██████████████████▌                       | 62/140 [03:34<04:23,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.00it/s]\u001b[A\n",
      " 45%|██████████████████▉                       | 63/140 [03:38<04:26,  3.46s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.76it/s]\u001b[A\n",
      " 46%|███████████████████▏                      | 64/140 [03:41<04:28,  3.53s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 46%|███████████████████▌                      | 65/140 [03:45<04:25,  3.54s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.78it/s]\u001b[A\n",
      " 47%|███████████████████▊                      | 66/140 [03:49<04:23,  3.56s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.96it/s]\u001b[A\n",
      " 48%|████████████████████                      | 67/140 [03:52<04:15,  3.50s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 49%|████████████████████▍                     | 68/140 [03:55<04:10,  3.48s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 49%|████████████████████▋                     | 69/140 [03:59<04:04,  3.44s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 50%|█████████████████████                     | 70/140 [04:02<04:01,  3.46s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 51%|█████████████████████▎                    | 71/140 [04:06<03:56,  3.43s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 51%|█████████████████████▌                    | 72/140 [04:09<03:50,  3.39s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 52%|█████████████████████▉                    | 73/140 [04:12<03:47,  3.40s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 53%|██████████████████████▏                   | 74/140 [04:16<03:42,  3.38s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 54%|██████████████████████▌                   | 75/140 [04:19<03:37,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.77it/s]\u001b[A\n",
      " 54%|██████████████████████▊                   | 76/140 [04:22<03:33,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 55%|███████████████████████                   | 77/140 [04:25<03:28,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 56%|███████████████████████▍                  | 78/140 [04:29<03:25,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 56%|███████████████████████▋                  | 79/140 [04:32<03:22,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.90it/s]\u001b[A\n",
      " 57%|████████████████████████                  | 80/140 [04:35<03:19,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 58%|████████████████████████▎                 | 81/140 [04:39<03:17,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 59%|████████████████████████▌                 | 82/140 [04:42<03:14,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.76it/s]\u001b[A\n",
      " 59%|████████████████████████▉                 | 83/140 [04:46<03:11,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 60%|█████████████████████████▏                | 84/140 [04:49<03:05,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 61%|█████████████████████████▍                | 85/140 [04:52<03:02,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.91it/s]\u001b[A\n",
      " 61%|█████████████████████████▊                | 86/140 [04:56<03:01,  3.36s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 62%|██████████████████████████                | 87/140 [04:59<02:55,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.91it/s]\u001b[A\n",
      " 63%|██████████████████████████▍               | 88/140 [05:02<02:52,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 64%|██████████████████████████▋               | 89/140 [05:05<02:48,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 64%|███████████████████████████               | 90/140 [05:09<02:46,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 65%|███████████████████████████▎              | 91/140 [05:12<02:40,  3.27s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 66%|███████████████████████████▌              | 92/140 [05:15<02:39,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 66%|███████████████████████████▉              | 93/140 [05:19<02:36,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.79it/s]\u001b[A\n",
      " 67%|████████████████████████████▏             | 94/140 [05:22<02:34,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 68%|████████████████████████████▌             | 95/140 [05:25<02:29,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.74it/s]\u001b[A\n",
      " 69%|████████████████████████████▊             | 96/140 [05:29<02:25,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n",
      " 69%|█████████████████████████████             | 97/140 [05:32<02:21,  3.28s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 70%|█████████████████████████████▍            | 98/140 [05:35<02:16,  3.24s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 71%|█████████████████████████████▋            | 99/140 [05:38<02:13,  3.26s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 71%|█████████████████████████████▎           | 100/140 [05:41<02:10,  3.26s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 72%|█████████████████████████████▌           | 101/140 [05:45<02:08,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 73%|█████████████████████████████▊           | 102/140 [05:48<02:06,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 74%|██████████████████████████████▏          | 103/140 [05:52<02:03,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 74%|██████████████████████████████▍          | 104/140 [05:55<02:00,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.79it/s]\u001b[A\n",
      " 75%|██████████████████████████████▊          | 105/140 [05:58<01:57,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n",
      " 76%|███████████████████████████████          | 106/140 [06:02<01:52,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 76%|███████████████████████████████▎         | 107/140 [06:05<01:49,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n",
      " 77%|███████████████████████████████▋         | 108/140 [06:08<01:46,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.76it/s]\u001b[A\n",
      " 78%|███████████████████████████████▉         | 109/140 [06:12<01:42,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      " 79%|████████████████████████████████▏        | 110/140 [06:15<01:40,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.78it/s]\u001b[A\n",
      " 79%|████████████████████████████████▌        | 111/140 [06:18<01:36,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 80%|████████████████████████████████▊        | 112/140 [06:22<01:33,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 81%|█████████████████████████████████        | 113/140 [06:25<01:28,  3.29s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 81%|█████████████████████████████████▍       | 114/140 [06:28<01:26,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 82%|█████████████████████████████████▋       | 115/140 [06:31<01:23,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 83%|█████████████████████████████████▉       | 116/140 [06:35<01:19,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.78it/s]\u001b[A\n",
      " 84%|██████████████████████████████████▎      | 117/140 [06:38<01:16,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n",
      " 84%|██████████████████████████████████▌      | 118/140 [06:41<01:12,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.78it/s]\u001b[A\n",
      " 85%|██████████████████████████████████▊      | 119/140 [06:45<01:09,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 86%|███████████████████████████████████▏     | 120/140 [06:48<01:05,  3.26s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.79it/s]\u001b[A\n",
      " 86%|███████████████████████████████████▍     | 121/140 [06:51<01:02,  3.28s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.75it/s]\u001b[A\n",
      " 87%|███████████████████████████████████▋     | 122/140 [06:54<00:59,  3.28s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.84it/s]\u001b[A\n",
      " 88%|████████████████████████████████████     | 123/140 [06:58<00:55,  3.28s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.81it/s]\u001b[A\n",
      " 89%|████████████████████████████████████▎    | 124/140 [07:01<00:52,  3.29s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.83it/s]\u001b[A\n",
      " 89%|████████████████████████████████████▌    | 125/140 [07:04<00:49,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 90%|████████████████████████████████████▉    | 126/140 [07:08<00:46,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 91%|█████████████████████████████████████▏   | 127/140 [07:11<00:42,  3.29s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 210.12it/s]\u001b[A\n",
      " 91%|█████████████████████████████████████▍   | 128/140 [07:14<00:40,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 92%|█████████████████████████████████████▊   | 129/140 [07:18<00:36,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.80it/s]\u001b[A\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 93%|██████████████████████████████████████   | 130/140 [07:21<00:33,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 94%|██████████████████████████████████████▎  | 131/140 [07:24<00:30,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.76it/s]\u001b[A\n",
      " 94%|██████████████████████████████████████▋  | 132/140 [07:28<00:26,  3.35s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.87it/s]\u001b[A\n",
      " 95%|██████████████████████████████████████▉  | 133/140 [07:31<00:23,  3.30s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 96%|███████████████████████████████████████▏ | 134/140 [07:34<00:19,  3.33s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.77it/s]\u001b[A\n",
      " 96%|███████████████████████████████████████▌ | 135/140 [07:38<00:16,  3.34s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.82it/s]\u001b[A\n",
      " 97%|███████████████████████████████████████▊ | 136/140 [07:41<00:13,  3.29s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.88it/s]\u001b[A\n",
      " 98%|████████████████████████████████████████ | 137/140 [07:44<00:09,  3.31s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.86it/s]\u001b[A\n",
      " 99%|████████████████████████████████████████▍| 138/140 [07:48<00:06,  3.32s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.85it/s]\u001b[A\n",
      " 99%|████████████████████████████████████████▋| 139/140 [07:51<00:03,  3.37s/it]\n",
      "  0%|                                                   | 0/139 [00:00<?, ?it/s]\u001b[A\n",
      "100%|████████████████████████████████████████| 139/139 [00:00<00:00, 209.89it/s]\u001b[A\n",
      "100%|█████████████████████████████████████████| 140/140 [07:54<00:00,  3.39s/it]\n"
     ]
    }
   ],
   "source": [
    "# # for flipped_label in range(total_num_labels):\n",
    "\n",
    "    \n",
    "\n",
    "    \n",
    "for k in tqdm(range(len(train_node_idx))):\n",
    "# for k in [102]:\n",
    "#     for k in range(10):\n",
    "\n",
    "\n",
    "#         train_y[k] = flipped_label\n",
    "    train_x = feat0[train_mask].numpy().astype(np.float32)\n",
    "    train_y = labels[train_mask].numpy().astype(np.float32)\n",
    "\n",
    "    val_x = feat0[test_mask].numpy().astype(np.float32)\n",
    "    val_y = labels[test_mask].numpy().astype(np.float32)\n",
    "    \n",
    "    enc = OneHotEncoder(handle_unknown='ignore')\n",
    "    enc.fit(train_y.reshape(-1, 1))\n",
    "\n",
    "    one_hot_labels_train = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "    one_hot_labels_val = enc.transform(val_y.reshape(-1, 1)).toarray()\n",
    "    \n",
    "    lr_origin = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "\n",
    "    lr_origin.fit(train_x, train_y, sample_weight=None, verbose=False)\n",
    "    \n",
    "    logits_val_y_origin = val_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    logits_train_y_origin = train_x @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "    ori_val_loss, ave_ori_val_loss = lr_origin.log_loss(logits_val_y_origin, one_hot_labels_val, l2_reg=True)\n",
    "\n",
    "    # numpy_theoritic_loss = log_loss(val_y, softmax(logits_val_y_origin, axis=1))\n",
    "    # # set l2_reg to False, verify the correctness of calculations\n",
    "    # assert np.allclose(numpy_theoritic_loss, ave_ori_val_loss)\n",
    "\n",
    "    val_loss_total_grad_orig, val_loss_indiv_grad_orig = lr_origin.grad(val_x, \n",
    "                                                                        logits_val_y_origin,\n",
    "                                                                        one_hot_labels_val, l2_reg = True)\n",
    "\n",
    "    hess = lr_origin.hess_cuda(train_x, logits_train_y_origin, l2_reg = True)\n",
    "    \n",
    "    loss_grad_hvp = fast_get_inv_hvp_cuda(hess, val_loss_total_grad_orig.T, cholskey=True)\n",
    "    \n",
    "    loss_grad_hvp = cp.asnumpy(loss_grad_hvp)\n",
    "            \n",
    "    del hess\n",
    "    \n",
    "    for flipped_label in range(total_num_labels):\n",
    "\n",
    "    # convert to one-hot labels\n",
    "        \n",
    "        train_y[k] = flipped_label\n",
    "        \n",
    "        one_hot_labels_train = enc.transform(train_y.reshape(-1, 1)).toarray()\n",
    "        \n",
    "        node_id = train_node_idx.numpy()[k]\n",
    "        nis = NodeInfluenceSGC(graph = graph, feature=feat, node_index=node_id)\n",
    "\n",
    "        # 2, remove the edges, calculate the perturbated feature\n",
    "        nis.remove_edges_sgc()\n",
    "        feat_removed1 = nis.calculate_modified_features()\n",
    "\n",
    "        extra_index = torch.unique(torch.where(feat0 != feat_removed1)[0])\n",
    "\n",
    "\n",
    "        extra_index_train = torch.tensor(\n",
    "            [extra_index[i] for i in range(len(extra_index)) if extra_index[i] in train_node_idx]).numpy()\n",
    "\n",
    "        extra_index_train_in_train = [\n",
    "            np.where(train_node_idx.numpy() == extra_index_train[j])[0][0] for j in range(len(extra_index_train))]\n",
    "\n",
    "        # 1, we need to remove the changed node feature from the perturbated feature, \n",
    "        # let it not added to the original feature\n",
    "\n",
    "\n",
    "        \"\"\"modified node features\"\"\"\n",
    "        extra_index_train_remove_node = extra_index_train.copy()\n",
    "        relative_node_id = np.where(extra_index_train_remove_node == node_id)[0]\n",
    "        extra_index_train_remove_node = np.delete(extra_index_train_remove_node, relative_node_id)\n",
    "        feat_to_be_added = feat_removed1[extra_index_train_remove_node].numpy()\n",
    "\n",
    "        \"\"\"index corresponding to modified node features\"\"\"\n",
    "        perturb_index = extra_index_train_in_train\n",
    "        added_index = perturb_index.copy()\n",
    "        added_index.remove(k)\n",
    "\n",
    "\n",
    "\n",
    "        train_x_new = feat_to_be_added\n",
    "        train_y_new = train_y[added_index]\n",
    "\n",
    "        train_x_orig = np.concatenate([train_x, train_x_new])\n",
    "        train_y_orig = np.concatenate([train_y, train_y_new])\n",
    "\n",
    "\n",
    "        one_hot_labels_train_0 = enc.transform(train_y_orig.reshape(-1, 1)).toarray()\n",
    "        logits_train_y_origin_0 = train_x_orig @ lr_origin.model.coef_.T + lr_origin.model.intercept_\n",
    "\n",
    "        train_total_grad_orig, train_indiv_grad_orig = lr_origin.grad(train_x_orig, \n",
    "                                                logits_train_y_origin_0, \n",
    "                                                one_hot_labels_train_0, l2_reg = True)\n",
    "\n",
    "\n",
    "        pred_infl = train_indiv_grad_orig.dot(loss_grad_hvp)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "        weight_3 = np.ones(len(train_x_orig))\n",
    "        weight_3[perturb_index] = 0 # 1...0...11\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "        lr_new_2 = SimplifiedGraphNeuralNetwork(l2_reg=l2_term, fit_intercept=True)\n",
    "        train_x_delete_2 = train_x_orig[weight_3 == 1]\n",
    "        train_y_delete_2 = train_y_orig[weight_3 == 1]\n",
    "\n",
    "        lr_new_2.fit(train_x_delete_2, train_y_delete_2)\n",
    "\n",
    "        logits_val_y_new_2 = val_x @ lr_new_2.model.coef_.T + lr_new_2.model.intercept_\n",
    "        new_ori_val_loss_2, _ = lr_new_2.log_loss(logits_val_y_new_2, one_hot_labels_val, l2_reg = True)\n",
    "\n",
    "        predict_influence_1.append(np.sum(pred_infl[perturb_index]) - np.sum(pred_infl[len(train_x):]))\n",
    "        acctual_influence_1.append(new_ori_val_loss_2 - ori_val_loss)\n",
    "\n",
    "        p_if_temp = np.sum(pred_infl[perturb_index]) - np.sum(pred_infl[len(train_x):])\n",
    "        a_if_temp = new_ori_val_loss_2 - ori_val_loss\n",
    "\n",
    "\n",
    "        pred_infl_mat[k][flipped_label] =p_if_temp\n",
    "        act_infl_mat[k][flipped_label] = a_if_temp\n",
    "        \n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a7c21794",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_pred = pd.DataFrame(pred_infl_mat)\n",
    "# df_pred.to_csv('result_flip_attack/cora_pred_infl_flip_class.csv')\n",
    "\n",
    "# df_act = pd.DataFrame(act_infl_mat)\n",
    "# df_act.to_csv('result_flip_attack/cora_act_infl_flip_class.csv')\n",
    "\n",
    "\n",
    "# df_pred = pd.DataFrame(pred_infl_mat)\n",
    "# df_pred.to_csv('result_flip_attack/single_cora_pred_infl_flip_class.csv')\n",
    "\n",
    "# df_act = pd.DataFrame(act_infl_mat)\n",
    "# df_act.to_csv('result_flip_attack/single_cora_act_infl_flip_class.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "87824f97",
   "metadata": {},
   "outputs": [],
   "source": [
    "# k, flipped_label"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "fe9c4a8a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1000, 7)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logits_val_y_new_2.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "57b0f703",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((1000, 1433), (1433, 7), (7,), (1000, 7))"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_x.shape, lr_new_2.model.coef_.T.shape, lr_new_2.model.intercept_.shape, one_hot_labels_val.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a1059209",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-3.659302904886843,\n",
       " -4.789748990918884,\n",
       " -4.294376478003954,\n",
       " 6.578244217103734,\n",
       " 3.6236688480429855,\n",
       " -2.4111009282788416,\n",
       " -4.07422231543876,\n",
       " -3.2857904162971643,\n",
       " -4.59696059331085,\n",
       " -4.2220494745504595,\n",
       " 6.95000332357592,\n",
       " 3.264050152206025,\n",
       " -1.8700673361933653,\n",
       " -3.5360732507425077,\n",
       " -2.2298752214674593,\n",
       " -1.6085206453755587,\n",
       " -1.261966479433827,\n",
       " 5.404340575708829,\n",
       " -0.043111276260930254,\n",
       " 0.28912272884182144,\n",
       " -2.2693014678189503,\n",
       " -16.962792819642335,\n",
       " -15.421010638922233,\n",
       " -14.986621256279541,\n",
       " -4.5028980868289565,\n",
       " 0.46614409363255516,\n",
       " -16.418632813763175,\n",
       " -17.001211363282593,\n",
       " 0.45280918759657496,\n",
       " -3.2247210448546397,\n",
       " -4.878508311009291,\n",
       " 1.4864693312223558,\n",
       " 2.4763761318509445,\n",
       " -3.792957087807835,\n",
       " -1.0476174649867076,\n",
       " -0.4337381150894366,\n",
       " -2.373145503030708,\n",
       " -0.5178956603309786,\n",
       " 9.05323464243953,\n",
       " 0.01776983032999979,\n",
       " -1.210033439798453,\n",
       " -0.7985143349849722,\n",
       " -0.5069905592787922,\n",
       " -2.4976539087718788,\n",
       " -0.4603706917139778,\n",
       " 8.194540353318805,\n",
       " -0.3179983206609922,\n",
       " -1.0399144841638055,\n",
       " -0.3272790651132471,\n",
       " -0.784763310133477,\n",
       " -2.821204714991546,\n",
       " -0.8616305643447122,\n",
       " 6.528795796451939,\n",
       " -0.8887381414069813,\n",
       " -1.3265777784936912,\n",
       " -0.16852731649533848,\n",
       " -0.4647269691944853,\n",
       " -2.603888081656807,\n",
       " -0.7656997412854327,\n",
       " 7.72933650742632,\n",
       " -0.3173958802905883,\n",
       " -1.3794676866015525,\n",
       " -0.48210728843767114,\n",
       " 0.29031509743980966,\n",
       " -2.033747690977468,\n",
       " -1.7568011670861727,\n",
       " 8.10443949315924,\n",
       " 0.9936179531514222,\n",
       " -2.085195774579586,\n",
       " -1.0827958721807436,\n",
       " -2.2352246020801143,\n",
       " -2.6776367130348575,\n",
       " -3.2593068219902577,\n",
       " 6.559233223746151,\n",
       " 0.8968220838304148,\n",
       " -4.412539607008789,\n",
       " -4.750981031926024,\n",
       " -4.33988456014226,\n",
       " -3.1685915724110316,\n",
       " -7.191818033142901,\n",
       " 0.981338058282998,\n",
       " -0.848552560129245,\n",
       " -7.7359894395041735,\n",
       " -8.37587973570951,\n",
       " -0.7173456580392994,\n",
       " -2.1365784646794648,\n",
       " -0.21174447605294766,\n",
       " 7.951838677045835,\n",
       " 0.6099888711425976,\n",
       " -2.2942123861265244,\n",
       " -0.39803008634127046,\n",
       " -2.061703096419471,\n",
       " -3.645643279964009,\n",
       " -1.0929089136859034,\n",
       " 7.425205363648754,\n",
       " 1.9721097714276112,\n",
       " -2.2648709370572178,\n",
       " -2.187347442133234,\n",
       " -2.65918987829966,\n",
       " -2.4907618912065104,\n",
       " -1.0402801233963181,\n",
       " 6.480727232000046,\n",
       " -0.3636864723887818,\n",
       " -2.64335520316142,\n",
       " -0.6490436820592116,\n",
       " 1.380455792461703,\n",
       " -2.220735567545951,\n",
       " -2.070375207447226,\n",
       " 3.1639193969118793,\n",
       " -2.392825888634192,\n",
       " 0.859126820019867,\n",
       " 0.048143856951144315,\n",
       " -9.66224445651688,\n",
       " -12.82601513892358,\n",
       " -10.156215588488081,\n",
       " 5.056177243946571,\n",
       " -11.53305635944909,\n",
       " -11.049306320990844,\n",
       " -10.11654874237098,\n",
       " -1.5787139352064727,\n",
       " -4.24266311097368,\n",
       " -0.9193350255501445,\n",
       " 7.354486596761809,\n",
       " -1.682440547274659,\n",
       " -1.105069540635764,\n",
       " 0.18013260086811922,\n",
       " -5.516057674583081,\n",
       " -5.579220012921117,\n",
       " -4.429397932574965,\n",
       " 4.235108786484091,\n",
       " -1.5627796406403789,\n",
       " 1.1226855369789828,\n",
       " -5.903728315767758,\n",
       " -2.4862615448334893,\n",
       " -3.9280630358327677,\n",
       " -2.1021844243439567,\n",
       " 4.867882161528634,\n",
       " 0.7003690136657994,\n",
       " 0.7100957939174624,\n",
       " -5.271058234345517,\n",
       " -2.3838865025858453,\n",
       " -2.9165010697197777,\n",
       " -2.9923127850560824,\n",
       " 4.372131071820071,\n",
       " -0.31080164654755293,\n",
       " 0.6909991639456576,\n",
       " -5.170617717248103,\n",
       " -3.6238446834086337,\n",
       " -4.803923512113364,\n",
       " -3.9441189009479816,\n",
       " 2.9289456878448954,\n",
       " -1.2769798760650266,\n",
       " 1.1244498818725015,\n",
       " -5.117611678522883,\n",
       " -3.1114263070453827,\n",
       " -4.244314659317455,\n",
       " -3.301701354342505,\n",
       " 6.231798134915154,\n",
       " -0.2744061200116885,\n",
       " 0.8165306946110409,\n",
       " -6.086259404647061,\n",
       " 1.5816041409505104,\n",
       " -2.0347601999641274,\n",
       " 0.6584999335733226,\n",
       " 8.250556772348958,\n",
       " -0.19814204101339783,\n",
       " -1.0134985432585744,\n",
       " 0.9710008371635812,\n",
       " -2.73134897461338,\n",
       " -2.4289737244869523,\n",
       " -1.961938425215239,\n",
       " 7.575345746218355,\n",
       " -1.1915150584270124,\n",
       " 0.24129920268072702,\n",
       " -4.477648181180735,\n",
       " -6.078205172112067,\n",
       " -7.6805100603322325,\n",
       " -7.407218049372268,\n",
       " 0.16888470287493007,\n",
       " -4.57109393980944,\n",
       " 1.228539138520107,\n",
       " -8.163110009297627,\n",
       " -2.151644821544087,\n",
       " -3.1317606613990012,\n",
       " 0.984245355206971,\n",
       " 7.408956450796277,\n",
       " -0.34645358219156286,\n",
       " -4.282841564908894,\n",
       " -5.718071984214191,\n",
       " -5.06196120903213,\n",
       " -4.270280382855613,\n",
       " 1.03223368705555,\n",
       " 7.21412399740267,\n",
       " -4.099471899621324,\n",
       " -1.4867596534346674,\n",
       " -4.933705877982325,\n",
       " -0.30510687645708856,\n",
       " -3.6805708507471895,\n",
       " 0.7419533152120454,\n",
       " 4.061942185790812,\n",
       " -0.06217545338473229,\n",
       " -3.523527033584269,\n",
       " -5.382503600524361,\n",
       " -5.047468615964441,\n",
       " -7.139574945562366,\n",
       " -5.64910977813512,\n",
       " 8.448205061925464,\n",
       " -5.097665347217461,\n",
       " -6.754809703087318,\n",
       " -9.113260425101466,\n",
       " -4.23125614416754,\n",
       " -3.8255761032852096,\n",
       " 3.008432705641402,\n",
       " 8.76746178539045,\n",
       " -6.341168142942832,\n",
       " -6.4570758546708635,\n",
       " -7.395505818143979,\n",
       " -1.0216958438475547,\n",
       " -3.0881581420985658,\n",
       " 0.6735715229330363,\n",
       " 2.8702986488746216,\n",
       " 0.8037688854934952,\n",
       " -3.141152522667751,\n",
       " -3.8288398271548214,\n",
       " -1.4506332476706163,\n",
       " 0.0968025453007364,\n",
       " -1.5887562476975958,\n",
       " 6.136791647938807,\n",
       " 0.5773936799401227,\n",
       " -0.6637026490345903,\n",
       " -2.609226621028345,\n",
       " -1.9697935836451386,\n",
       " 0.8544637468267133,\n",
       " -2.672670931110087,\n",
       " 3.1537426654880356,\n",
       " -0.6707473670705006,\n",
       " -2.980769188488928,\n",
       " -3.7155473266319703,\n",
       " -0.8280763787792651,\n",
       " -4.554252437175911,\n",
       " -4.978582949438945,\n",
       " 4.826843773230763,\n",
       " 1.9365295795373214,\n",
       " -4.26255274173684,\n",
       " -5.122822587863148,\n",
       " 1.5714405414694106,\n",
       " -4.830636552774612,\n",
       " -4.361406951075322,\n",
       " 3.9464567356343725,\n",
       " -2.6890128453097812,\n",
       " -4.142961083527672,\n",
       " -6.0171547863514885,\n",
       " 2.1526764294236873,\n",
       " -2.442924598876905,\n",
       " -0.47746983981713775,\n",
       " 8.359019392834591,\n",
       " -0.08841073529248966,\n",
       " -1.406841668965301,\n",
       " -2.045478987538095,\n",
       " -3.6572534018381937,\n",
       " -4.946510592342264,\n",
       " -5.771408553935331,\n",
       " 5.719585932125874,\n",
       " -1.8709736466469877,\n",
       " -4.959034212456594,\n",
       " -6.881533445124489,\n",
       " 0.8092169524100878,\n",
       " -2.243598077766551,\n",
       " 0.26480326583924274,\n",
       " 7.753245544715886,\n",
       " -0.10719036927774006,\n",
       " -1.3017319094751567,\n",
       " -0.6009149525014585,\n",
       " 1.48737482872553,\n",
       " -4.434364206459998,\n",
       " -3.0136167579559814,\n",
       " 1.8106293539233267,\n",
       " -0.9218469611935696,\n",
       " -3.0354620690990988,\n",
       " -4.599103687783677,\n",
       " 0.7828188391335473,\n",
       " -2.5988384030276315,\n",
       " -3.327079136908818,\n",
       " 3.170261735763056,\n",
       " 1.1224234726909401,\n",
       " -0.20633316373861632,\n",
       " -0.289629495177234,\n",
       " 0.33078002000121653,\n",
       " -2.5078179663264573,\n",
       " -1.7890296974467832,\n",
       " 6.7761073765994295,\n",
       " 0.13518017521534187,\n",
       " -0.005058964263327859,\n",
       " -2.4593816065641905,\n",
       " -1.6002307281792172,\n",
       " -4.335179471601694,\n",
       " -2.9405854722299436,\n",
       " 4.221752751548894,\n",
       " -0.8941613452277837,\n",
       " 0.880176084331338,\n",
       " -3.4065943314427054,\n",
       " -1.2591607647082155,\n",
       " -3.2975673725677153,\n",
       " -2.6533024667438125,\n",
       " 7.3089564601369865,\n",
       " 0.28650109079968633,\n",
       " 0.4225671141267613,\n",
       " -3.5059639085470016,\n",
       " -5.335740826582008,\n",
       " -6.34545973698706,\n",
       " -4.9420629561090905,\n",
       " 7.451005391640418,\n",
       " -6.054667062974211,\n",
       " -6.302242146998829,\n",
       " -7.039812678764157,\n",
       " -2.888647811586136,\n",
       " -6.376231542423696,\n",
       " -5.263390155390191,\n",
       " 6.599751024431832,\n",
       " -3.1891666771092133,\n",
       " -5.275807297328647,\n",
       " -6.490895558675035,\n",
       " -1.9493893301124592,\n",
       " -3.118837629603326,\n",
       " -2.101497545403393,\n",
       " 5.976924296261843,\n",
       " 1.2083584589063472,\n",
       " 0.4510507939748729,\n",
       " -3.355737484629409,\n",
       " -3.0372666471522436,\n",
       " -4.557168299100876,\n",
       " 2.3774737848713094,\n",
       " 1.4820741382397529,\n",
       " -3.348759092546402,\n",
       " -4.5270023143694615,\n",
       " -5.442294848003112,\n",
       " -0.8683904746709281,\n",
       " -0.7337751037067903,\n",
       " 0.923809420526208,\n",
       " 11.001237957785015,\n",
       " -1.5745991670218622,\n",
       " -1.7706495048264905,\n",
       " -4.9904704361608125,\n",
       " -4.825374840274346,\n",
       " -5.238069798389979,\n",
       " 2.0203939862642066,\n",
       " 5.141221845757602,\n",
       " -4.486367923025444,\n",
       " -6.6436788788177985,\n",
       " -6.632569673754613,\n",
       " -3.2516362736404503,\n",
       " -5.331131793871744,\n",
       " 1.9391918010927185,\n",
       " 2.59242825977897,\n",
       " -3.1412492122504574,\n",
       " -5.428188712770371,\n",
       " -7.056142208009128,\n",
       " -7.797437604080347,\n",
       " -10.200921838032176,\n",
       " 0.8561096691305004,\n",
       " -7.541075813646682,\n",
       " -9.002076397730075,\n",
       " -11.987362586574946,\n",
       " -11.76343161713013,\n",
       " -2.40070929212677,\n",
       " -4.442977818941941,\n",
       " 1.303117537373712,\n",
       " 5.491660607557549,\n",
       " -0.16474699856826902,\n",
       " -3.5337550048653874,\n",
       " -5.578628345845349,\n",
       " -1.9617976949960152,\n",
       " -2.527745014999578,\n",
       " 0.0037628333118320256,\n",
       " 10.055503355810458,\n",
       " -0.1319590872535059,\n",
       " -3.14368128266047,\n",
       " -4.709493320699508,\n",
       " -3.6631138145298006,\n",
       " -3.1540188007709555,\n",
       " -3.1425403554328404,\n",
       " 5.706571024017883,\n",
       " 0.0964512173024521,\n",
       " 0.5761740347809208,\n",
       " -5.08430465290682,\n",
       " -2.1932671980351035,\n",
       " -0.4848934910566989,\n",
       " -1.5657884016578532,\n",
       " 1.1864446308398993,\n",
       " -2.2256661313372508,\n",
       " 1.1890052286346524,\n",
       " -2.40349264386945,\n",
       " -1.2840660753204505,\n",
       " 0.4964086401742742,\n",
       " -2.3822047147159475,\n",
       " 4.5329745444751905,\n",
       " -0.23238195245662485,\n",
       " -2.9334456177020423,\n",
       " -3.719465418971226,\n",
       " 0.04244702151710911,\n",
       " -0.002980150666935799,\n",
       " -1.1283670596968385,\n",
       " 4.410012960644861,\n",
       " 1.2397399004899832,\n",
       " -2.2521754935596547,\n",
       " -3.9259531508298693,\n",
       " -3.770482632004061,\n",
       " -4.310346598054007,\n",
       " -0.11355686563472389,\n",
       " 6.094678945504938,\n",
       " -1.3159495187268426,\n",
       " -3.677794539026767,\n",
       " -5.175746130154902,\n",
       " 1.0146598808971206,\n",
       " -3.310927403484323,\n",
       " -1.8695440446143454,\n",
       " 2.0979792810774125,\n",
       " -0.8213509511167878,\n",
       " -3.537364669585161,\n",
       " -4.902282495420083,\n",
       " 1.2071696184260112,\n",
       " -2.8376668005591306,\n",
       " -1.9473792032767427,\n",
       " 8.527428807836127,\n",
       " 0.19467027632732226,\n",
       " -0.8604400053542456,\n",
       " -3.4298981400775084,\n",
       " 0.6813705085057506,\n",
       " -2.7207967960484005,\n",
       " -2.008750107839216,\n",
       " 7.03573342505339,\n",
       " 0.17117861556043223,\n",
       " -1.987958525208267,\n",
       " -2.7733848011074933,\n",
       " -1.7572270033800486,\n",
       " -3.3612077044400124,\n",
       " -2.473580089148527,\n",
       " 4.9444153937118465,\n",
       " -1.5527132230042113,\n",
       " 2.0351803088071314,\n",
       " -1.7860600688537573,\n",
       " -1.8121810586061748,\n",
       " -2.047441125359075,\n",
       " -3.737841490443838,\n",
       " 3.8426732408970707,\n",
       " -4.058553751189404,\n",
       " 0.1621320822545229,\n",
       " -2.650443672395067,\n",
       " 0.16311045558657433,\n",
       " -2.3196188460752953,\n",
       " -1.879657405245922,\n",
       " 6.510899991851813,\n",
       " -0.3483111401941148,\n",
       " -0.7934122726173722,\n",
       " -0.22398012577647464,\n",
       " -2.2287502516361037,\n",
       " -3.489672715638445,\n",
       " -1.9285078523089894,\n",
       " 5.5218075832603155,\n",
       " -1.2963536384249288,\n",
       " 0.9179174147064231,\n",
       " -4.697170384026489,\n",
       " -1.1573075609310335,\n",
       " -0.028267206036765025,\n",
       " -2.7922622783323616,\n",
       " 3.7667568248562846,\n",
       " -2.905470387928328,\n",
       " -1.8179674100771166,\n",
       " -4.636820055078496,\n",
       " 1.8347769567435002,\n",
       " -3.0860527107830205,\n",
       " -1.9058662243872302,\n",
       " 6.819994005864331,\n",
       " -1.4249980485270672,\n",
       " -3.1987122383035125,\n",
       " -4.2192542276716996,\n",
       " 0.749463701270642,\n",
       " -2.1916216100104258,\n",
       " -0.9879409396126171,\n",
       " 4.611527253654998,\n",
       " -1.8367827932505705,\n",
       " 0.6931113088785921,\n",
       " -0.662085376225857,\n",
       " 0.31045229588210077,\n",
       " -4.3357775957619005,\n",
       " -3.1170388227186585,\n",
       " 7.413118838336867,\n",
       " 0.18553873521932474,\n",
       " -4.098878345752208,\n",
       " -5.224725061892546,\n",
       " 0.9067092396105068,\n",
       " -2.167637563295635,\n",
       " -1.7384778046930656,\n",
       " 7.892921905037354,\n",
       " -0.5644115209807339,\n",
       " -1.2139034174349987,\n",
       " -1.7233144837992924,\n",
       " -1.3002541851909868,\n",
       " 1.0902559182917848,\n",
       " -1.3025315671624202,\n",
       " 0.6071891911657374,\n",
       " -2.4519607349998296,\n",
       " -1.4494451706662872,\n",
       " -3.2113464853488285,\n",
       " -0.8656569220207535,\n",
       " 0.9349725718965205,\n",
       " -1.6321710097426516,\n",
       " 4.25625311886627,\n",
       " -2.0249053760566786,\n",
       " -2.103881923741901,\n",
       " -3.524833148723597,\n",
       " -1.2937186799046225,\n",
       " 0.04479261356537645,\n",
       " -0.6718489357584589,\n",
       " 8.405784664385422,\n",
       " -1.8475138071064245,\n",
       " -2.7284798130042462,\n",
       " -3.676617485820235,\n",
       " -1.7364873200383135,\n",
       " -0.3757719058925444,\n",
       " -0.8875836538221753,\n",
       " 9.48301148331801,\n",
       " -2.2200381432217915,\n",
       " -2.248069109754918,\n",
       " -4.498313490276167,\n",
       " -0.22733544895257296,\n",
       " -2.1917877987562413,\n",
       " -1.8080952754874922,\n",
       " 8.185385650676913,\n",
       " -1.053074491958082,\n",
       " -1.5242772563002234,\n",
       " -2.7755387684371016,\n",
       " -7.21426203590832,\n",
       " -5.554279001196022,\n",
       " 3.8525446004238972,\n",
       " 1.8200646324478669,\n",
       " -8.356826137696189,\n",
       " -7.593452967902934,\n",
       " -9.265355882466988,\n",
       " -6.919006898465977,\n",
       " -7.921418937801391,\n",
       " 3.6558285888142024,\n",
       " -2.6354221994652036,\n",
       " -8.25167842204537,\n",
       " -8.212151438592468,\n",
       " -8.816897569304537,\n",
       " -8.030344278321685,\n",
       " -10.020986074951217,\n",
       " 1.2042468451044428,\n",
       " -7.974049771035936,\n",
       " -9.16362137753957,\n",
       " -10.969591909464139,\n",
       " -11.919944878389643,\n",
       " -1.2269609875362448,\n",
       " -2.5385993179571784,\n",
       " 0.8788705753908062,\n",
       " 6.119992325823006,\n",
       " -1.524393765805506,\n",
       " -1.2726022890355466,\n",
       " -3.96674392250317,\n",
       " -1.7663072173761094,\n",
       " -4.333798787141816,\n",
       " 1.7057675388146976,\n",
       " 4.256749764112165,\n",
       " -2.1905523776106435,\n",
       " -4.539885632841113,\n",
       " -5.583323056823701,\n",
       " -3.310593819496148,\n",
       " -4.438466950683562,\n",
       " 0.26876203604344084,\n",
       " 9.488126914460025,\n",
       " -3.3525645638892456,\n",
       " -5.595670047302363,\n",
       " -6.888205705396203,\n",
       " -1.2222627733156557,\n",
       " -3.8493573262991063,\n",
       " 0.6069550708565075,\n",
       " 7.963273288233687,\n",
       " -0.9388886224751545,\n",
       " -3.6299180324145297,\n",
       " -5.69141847733929,\n",
       " -1.3584093121215588,\n",
       " -4.063004469373475,\n",
       " 0.831048703349758,\n",
       " 7.777133316091955,\n",
       " -0.6779164254069983,\n",
       " -4.428309957979046,\n",
       " -5.7187218272574185,\n",
       " -0.5812267609581667,\n",
       " 0.3071451411891033,\n",
       " -1.0707003365938448,\n",
       " 4.746400025225783,\n",
       " -2.099773768430225,\n",
       " -1.958166320283766,\n",
       " -2.7938636348965886,\n",
       " 1.4473515042092995,\n",
       " -3.0319011589206273,\n",
       " -2.3874497373946166,\n",
       " 8.048426934631527,\n",
       " -0.5070713414088512,\n",
       " -1.4771542555065,\n",
       " -2.178055650009769,\n",
       " 0.49280782694891734,\n",
       " -2.70089994256241,\n",
       " -1.9890387378686771,\n",
       " 6.479645166073324,\n",
       " 0.7132268250164682,\n",
       " -0.8230585663167584,\n",
       " -1.4032815390022382,\n",
       " -1.594058415812551,\n",
       " -6.24952587575479,\n",
       " -4.891774675381672,\n",
       " 9.193147148613729,\n",
       " -4.454825956015565,\n",
       " -5.440510336393974,\n",
       " -6.029918597969319,\n",
       " -0.5197274280870019,\n",
       " -3.677980383202396,\n",
       " -3.667084086504751,\n",
       " 5.9914857764266,\n",
       " -2.198477293082057,\n",
       " -0.802091617923228,\n",
       " 0.0728417560160377,\n",
       " -4.982796373590517,\n",
       " -8.592766801781483,\n",
       " -5.825276685654686,\n",
       " 9.246989063882566,\n",
       " -7.142411067452528,\n",
       " -8.454596717742621,\n",
       " -9.8338938509651,\n",
       " 0.5260413558908041,\n",
       " -4.728809154341532,\n",
       " -3.3828605380754464,\n",
       " 8.27764789872601,\n",
       " -2.831430791948071,\n",
       " -4.0384317610388205,\n",
       " -4.852390202311403,\n",
       " 1.748376395126762,\n",
       " -3.0440900839782277,\n",
       " -2.8013750671196735,\n",
       " 7.456829430861021,\n",
       " -1.020772403272371,\n",
       " -3.3697161149717463,\n",
       " -4.382036516155958,\n",
       " -5.60185869600231,\n",
       " -6.125918436671986,\n",
       " -5.3254794812144635,\n",
       " 8.404165938310692,\n",
       " 1.2899713265190886,\n",
       " -5.976570053129093,\n",
       " -8.850949053579944,\n",
       " 0.7361946462431028,\n",
       " -2.7298413201481146,\n",
       " -0.4432484685009719,\n",
       " 8.229406545527144,\n",
       " -3.3002878677770475,\n",
       " -2.918182236229832,\n",
       " -3.099880976887878,\n",
       " 0.053931844156704045,\n",
       " -3.261619263708578,\n",
       " -1.6553295034602478,\n",
       " 5.3282866127546065,\n",
       " -0.2735180909886381,\n",
       " -0.994753939302484,\n",
       " -2.4572221278989907,\n",
       " -9.71373918123819,\n",
       " -12.149992192645591,\n",
       " -9.617094137211467,\n",
       " 10.91063964819839,\n",
       " -5.5891374376504785,\n",
       " -11.950341671811266,\n",
       " -13.680133683669858,\n",
       " -7.724133314367322,\n",
       " -8.490973494287708,\n",
       " -6.978468402098997,\n",
       " 2.5537078092579932,\n",
       " -5.354185762159823,\n",
       " -8.60793228163358,\n",
       " -10.85963295135543,\n",
       " -0.8496858996610612,\n",
       " -0.6210928259046362,\n",
       " -0.09987850917645602,\n",
       " 5.580049302135677,\n",
       " -2.2304370850145574,\n",
       " 0.5405808102084961,\n",
       " -2.5411454322213594,\n",
       " -16.047158547847854,\n",
       " -14.020725284260859,\n",
       " -12.766572864352174,\n",
       " 7.008275610689765,\n",
       " -12.7573272447902,\n",
       " -15.93281099364965,\n",
       " -16.0417545368924,\n",
       " -1.5095098007764083,\n",
       " 0.8721838583048553,\n",
       " -2.4158070004562564,\n",
       " 3.413420611746038,\n",
       " -2.551605611004833,\n",
       " -1.8522277095542439,\n",
       " -4.035316666614463,\n",
       " -1.8828550175759045,\n",
       " 1.1939905711357959,\n",
       " -2.2313549989215797,\n",
       " 1.8741932860322112,\n",
       " -3.307497305026571,\n",
       " -2.7227381763556178,\n",
       " -4.35680636692671,\n",
       " -2.9966737603361944,\n",
       " -0.6498682624428769,\n",
       " -2.005572116456034,\n",
       " 9.260509943420509,\n",
       " -5.867160536815818,\n",
       " -3.8838362227921985,\n",
       " -5.218719036453352,\n",
       " -0.5270333320461482,\n",
       " -3.1929703461615446,\n",
       " -1.0273642027345176,\n",
       " 8.602421374996705,\n",
       " -2.3224793046122407,\n",
       " 0.4663843981808853,\n",
       " -2.426052044879153,\n",
       " 0.9067612006195969,\n",
       " -3.30557076590671,\n",
       " -1.5212669800599592,\n",
       " 6.032837759055061,\n",
       " -0.6940600192063489,\n",
       " -1.5016231803493678,\n",
       " 0.02745122042911774,\n",
       " -0.6361409841263415,\n",
       " -3.8928904953885235,\n",
       " -3.2981357359900665,\n",
       " -0.24917143154384203,\n",
       " -0.015148426577488827,\n",
       " 4.30056574997175,\n",
       " -0.47450751285749515,\n",
       " 0.7089973456375382,\n",
       " -3.0761315910495206,\n",
       " -1.8512251742507857,\n",
       " 7.649734690806039,\n",
       " -1.5177713143272022,\n",
       " -1.1854743696556795,\n",
       " -1.0500786781816984,\n",
       " 2.0081088600489494,\n",
       " -6.652166242486395,\n",
       " -5.778661909232788,\n",
       " -5.55884562975848,\n",
       " -5.6075472582032795,\n",
       " -4.7742033235079475,\n",
       " -5.067666070577005,\n",
       " 1.4799995393477445,\n",
       " -4.228712336191155,\n",
       " -4.051803739124988,\n",
       " 2.679104746728779,\n",
       " 1.5410229348904387,\n",
       " -3.3329324621094862,\n",
       " -4.534085113882579,\n",
       " 0.6653485507254366,\n",
       " -3.7863477522204185,\n",
       " -2.41160449199403,\n",
       " 9.441240575485207,\n",
       " 1.6661368462269657,\n",
       " -3.9683493966652925,\n",
       " -4.417785615666713,\n",
       " 1.2216395318380258,\n",
       " -0.3551771128710648,\n",
       " -0.7166340302780476,\n",
       " 4.984972342279182,\n",
       " -0.6879931084999988,\n",
       " -2.554754071627034,\n",
       " -2.543659505952359,\n",
       " -4.441072297940181,\n",
       " -7.215670423758576,\n",
       " -7.290208920097131,\n",
       " 8.318087155960693,\n",
       " 1.980989042710748,\n",
       " -7.944488585326463,\n",
       " -9.165467107016037,\n",
       " -0.8335744199320061,\n",
       " -4.165212887892908,\n",
       " -4.042348736319669,\n",
       " 5.58680364628734,\n",
       " 2.4422462577332205,\n",
       " -4.452370341207123,\n",
       " -5.215473804710074,\n",
       " -0.7039468897876056,\n",
       " 1.733724831451216,\n",
       " -2.1614364055709423,\n",
       " 4.008923600575251,\n",
       " -1.553429775046002,\n",
       " -1.352972812875322,\n",
       " -4.348549964468824,\n",
       " -8.762273306279864,\n",
       " -10.143607300965177,\n",
       " -9.057479971074988,\n",
       " 11.820161235285074,\n",
       " -7.716709399925454,\n",
       " -10.351265403222241,\n",
       " -11.990721996323343,\n",
       " -4.36368420437978,\n",
       " 1.447256268993499,\n",
       " -2.310034617105188,\n",
       " -4.1408518825663805,\n",
       " -7.097059331664838,\n",
       " -1.6221535124823703,\n",
       " -4.285186983633068,\n",
       " -4.173209964738369,\n",
       " -5.805718930973249,\n",
       " -5.39651917380953,\n",
       " 8.77532530259976,\n",
       " -1.532226722957951,\n",
       " -5.152723941628047,\n",
       " -6.339529135066378,\n",
       " -1.1482732928470405,\n",
       " -4.338857416468908,\n",
       " -4.086718408205105,\n",
       " 9.264887612064385,\n",
       " -0.1034505275452311,\n",
       " -4.198773890327164,\n",
       " -5.234784904027872,\n",
       " -1.9828432058231087,\n",
       " -4.952848918749588,\n",
       " -3.821430251195764,\n",
       " 10.792986940776878,\n",
       " -1.1478625823434996,\n",
       " -5.145606459935998,\n",
       " -6.2740669999918595,\n",
       " 0.3584948040387701,\n",
       " 0.3355731679575271,\n",
       " -1.057144083081326,\n",
       " 8.08701893350792,\n",
       " -2.086848223572808,\n",
       " -1.8640217209866066,\n",
       " -2.7786968659199793,\n",
       " 1.5303491508085187,\n",
       " -1.5235466381612568,\n",
       " -0.17353825703163395,\n",
       " 9.755748260371544,\n",
       " -1.8847347327077202,\n",
       " -2.3523200246355884,\n",
       " -2.364792246388024,\n",
       " 1.4327389204864573,\n",
       " -5.021429359739187,\n",
       " -2.7150820806514417,\n",
       " -3.1352963263319253,\n",
       " -5.1871111130626275,\n",
       " -0.6737998372317833,\n",
       " 0.10705359726287611,\n",
       " -5.783742159278486,\n",
       " -8.646192086051098,\n",
       " -7.04171548779183,\n",
       " 9.117996889180151,\n",
       " -6.246082053610575,\n",
       " -8.139803743426345,\n",
       " -9.634039714896485,\n",
       " -1.0721945030354743,\n",
       " -4.133634417817257,\n",
       " -3.928978894837295,\n",
       " 5.995787036740085,\n",
       " 0.8460390572009224,\n",
       " -4.732808942207386,\n",
       " -4.7872896466532655,\n",
       " -0.9921379654741393,\n",
       " -3.74765023921414,\n",
       " -4.749024350369924,\n",
       " 9.98250782780098,\n",
       " -0.59077285459324,\n",
       " -4.47259434545199,\n",
       " -5.803667251434129,\n",
       " -2.3812484856845817,\n",
       " -4.562879462232912,\n",
       " -3.89488124709875,\n",
       " 4.050027701468929,\n",
       " 2.375028985107617,\n",
       " -4.047669280446213,\n",
       " -5.789532697251955,\n",
       " 1.4901389644410088,\n",
       " -3.9550151765762394,\n",
       " -2.8343329852271424,\n",
       " 2.7907557606825577,\n",
       " 1.552701968234956,\n",
       " -2.5869191721377334,\n",
       " -2.6642769234682717,\n",
       " -11.541099009716937,\n",
       " -12.342420178315585,\n",
       " -10.398828602027216,\n",
       " 6.593977808341954,\n",
       " -9.0075136433395,\n",
       " -12.251530890780906,\n",
       " -14.497609613651,\n",
       " -3.8722449193833697,\n",
       " -5.733461459846843,\n",
       " -5.162136229184945,\n",
       " 11.780947372056652,\n",
       " -2.6633230353073856,\n",
       " -6.2457531096507495,\n",
       " -7.508205930179109,\n",
       " 1.7177453462756596,\n",
       " -3.2438350991010125,\n",
       " -2.1906031313260392,\n",
       " 4.677207103218262,\n",
       " -1.7299848957930664,\n",
       " -1.0427128423843008,\n",
       " -0.42316680455316913,\n",
       " -2.246946078129824,\n",
       " -4.973168823763203,\n",
       " -3.7908348175865,\n",
       " 9.382201547294045,\n",
       " -0.5178156173925004,\n",
       " -5.088110617275859,\n",
       " -5.8658815479276285,\n",
       " -1.9173677119546113,\n",
       " -4.0143120225751545,\n",
       " 0.7659162262719121,\n",
       " 8.538012509275305,\n",
       " -1.8807865875609622,\n",
       " -4.14307876075415,\n",
       " -5.218572239262954,\n",
       " -3.4183243584359957,\n",
       " -4.329991871304735,\n",
       " 0.14048311802687152,\n",
       " 10.649252262974347,\n",
       " -3.8338243237901892,\n",
       " -5.176268890460076,\n",
       " -5.273205803230567,\n",
       " -7.73664119505974,\n",
       " -7.981451642259925,\n",
       " -7.570700063052334,\n",
       " 5.322479378745835,\n",
       " 1.4939937833458172,\n",
       " -9.889781897646492,\n",
       " -10.644912007635396,\n",
       " -9.056954460071907,\n",
       " -9.431394107880386,\n",
       " -7.907814580512544,\n",
       " 8.954235064046557,\n",
       " -0.06241236489445967,\n",
       " -11.697730794342789,\n",
       " -12.528170303642177,\n",
       " -5.59771592814846,\n",
       " -7.829952668980916,\n",
       " -6.770150177909109,\n",
       " 8.985310810275905,\n",
       " -3.6266183144082618,\n",
       " -7.8768062685938816,\n",
       " -8.173486746636542,\n",
       " 2.4569413526734003,\n",
       " -3.668141540094105,\n",
       " -3.5173821803978953,\n",
       " 1.9591990705040914,\n",
       " -2.1970659805479613,\n",
       " -3.5562653267428956,\n",
       " -3.208373983814262,\n",
       " -1.5132587865238065,\n",
       " -5.942693115718093,\n",
       " -6.659386043218305,\n",
       " 3.471287936005716,\n",
       " 4.962581946854492,\n",
       " -4.79446189635479,\n",
       " -5.135558548484653,\n",
       " -6.354999592971601,\n",
       " -8.357853321391222,\n",
       " -8.334625045876205,\n",
       " 4.441403165590309,\n",
       " 3.4095001785712,\n",
       " -7.970784427452995,\n",
       " -9.3728115492225,\n",
       " -3.384553190418438,\n",
       " -6.727254486520208,\n",
       " -6.298167212819322,\n",
       " 6.691631485475691,\n",
       " 2.933890115635462,\n",
       " -7.484011137493908,\n",
       " -7.526363990884156,\n",
       " -7.460852247366537,\n",
       " -10.553035484869907,\n",
       " -10.890280458854496,\n",
       " 1.61318402959016,\n",
       " 3.437499870730816,\n",
       " -10.952990988249956,\n",
       " -10.686638625342324]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "predict_influence_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "86700981",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "low_limit = -20\n",
    "up_limit = 20\n",
    "\n",
    "sns.set_theme()\n",
    "sns.set_style(\"whitegrid\")\n",
    "low_limit = -20\n",
    "up_limit = 20\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "plt.axis('square')\n",
    "plt.xlabel('Act. Influence')\n",
    "plt.ylabel('Pred. Influence')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(low_limit, up_limit)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "eeca08b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_pred = pd.DataFrameme(pred_infl_mat)\n",
    "# df_pred.to_csv('result_flip_attack/cora_pred_infl_flip_class.csv')\n",
    "\n",
    "# df_act = pd.DataFrameme(act_infl_mat)\n",
    "# df_act.to_csv('result_flip_attack/cora_act_infl_flip_class.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "31ce35e2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=-0.3218721259442059, pvalue=4.658347734283298e-25)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(np.array(acctual_influence_1)[np.array(acctual_influence_1) !=0], np.array(predict_influence_1)[np.array(predict_influence_1) !=0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "60ceac5a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=-0.3218721259442059, pvalue=4.658347734283298e-25)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "scipy.stats.spearmanr(acctual_influence_1, predict_influence_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "2f37c13c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# data1 = pd.DataFrame([time_infl[i] / time_retrain[i] for i in range(len(time_infl))])\n",
    "# data1.to_csv('running time/citeseer_running_time.csv', header = None, index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "d8e6f0d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame([acctual_influence_1, predict_influence_1]).T\n",
    "df.columns = ['acctual_influence', 'predict_influence']\n",
    "# df.to_csv('complete_node/' +data_set + '.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "4444c34d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pd.read_csv('complete_node/cora_flip.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "5f568f34",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138]"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "added_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "312d0601",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "139"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "k"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "0dbad1af",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138, 139]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "perturb_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "0d0d48da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(143, 1433)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_x_orig.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "8209cf2d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1., 1.,\n",
       "       0., 0., 0., 0., 1., 1., 1.])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "weight_3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "34afd7bb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([136, 137, 138, 139]),)"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.where(weight_3 == 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "7bb5efd4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[136, 137, 138, 139]"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "perturb_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "6314242a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0., 4., 4.], dtype=float32)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_y_new"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "f978ef6e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4., 4., 5., 4., 0., 6., 6., 6., 6., 6., 4., 3., 6., 6., 6., 6., 3.,\n",
       "       6., 5., 5., 5., 5., 5., 6., 5., 5., 2., 2., 2., 3., 1., 2., 1., 1.,\n",
       "       4., 0., 6., 3., 6., 0., 6., 5., 5., 5., 3., 3., 5., 2., 1., 2., 2.,\n",
       "       2., 2., 2., 5., 5., 1., 1., 3., 0., 0., 0., 5., 3., 6., 5., 1., 0.,\n",
       "       6., 3., 5., 1., 1., 1., 1., 0., 2., 2., 2., 2., 2., 2., 2., 2., 1.,\n",
       "       5., 5., 3., 6., 3., 0., 0., 4., 0., 0., 3., 3., 1., 3., 1., 1., 1.,\n",
       "       5., 6., 6., 0., 0., 0., 0., 1., 4., 4., 0., 3., 1., 3., 4., 4., 1.,\n",
       "       1., 0., 3., 4., 4., 4., 4., 3., 3., 6., 4., 2., 2., 4., 4., 3., 0.,\n",
       "       0., 4., 4., 6., 0., 4., 4.], dtype=float32)"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_y_orig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "3cec9172",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6.0"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_y_orig[k]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d08110d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
