{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1cc50f14",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from pyvis.network import Network\n",
    "from tqdm import tqdm\n",
    "import os\n",
    "import dgl\n",
    "import torch\n",
    "import networkx as nx\n",
    "from dataset import load_graph_dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "229db860",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 2708\n",
      "  NumEdges: 10556\n",
      "  NumFeats: 1433\n",
      "  NumClasses: 7\n",
      "  NumTrainingSamples: 140\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset('cora')\n",
    "train_mask = train_mask.numpy()\n",
    "train_node_index= np.where(train_mask == 1)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "978759f6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4, 4, 4, ..., 4, 3, 3])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3c0474f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "14427561",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_node_feature = pd.read_csv('node_feature_2/cora.csv')\n",
    "df_node_preprocessed = df_node_feature.drop(columns = ['predicted influence'])\n",
    "df_node_preprocessed['node_id'] = train_node_index\n",
    "df_node_preprocessed = df_node_preprocessed.sort_values(['actual influence'], ascending = False)\n",
    "df_node_preprocessed.index = range(len(df_node_preprocessed))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9bd0631a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "80229e00",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge = pd.read_csv('edge_feature/cora_edge_influence_001.csv', header = None)\n",
    "df_edge.columns = ['actual_influence', 'predicted_influence', 'from_edges', 'to_edges']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5d302d12",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_influence = df_edge.groupby(['from_edges', 'to_edges']).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "3f8e52bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_actual_edge_influence(df_edge):\n",
    "    new_infl = []\n",
    "    df_edge_copy = df_edge.copy()\n",
    "    for i in tqdm(range(len(df_edge))):\n",
    "        f = df_edge.loc[i, ['from_edges']].values[0]\n",
    "        t = df_edge.loc[i, ['to_edges']].values[0]\n",
    "\n",
    "        act_1 = df_edge[(df_edge['from_edges'] == f) & (df_edge['to_edges'] == t)].actual_influence.values[0]\n",
    "        act_2 = df_edge[(df_edge['from_edges'] == t) & (df_edge['to_edges'] == f)].actual_influence.values[0]\n",
    "        new_infl.append((act_1 + act_2))\n",
    "    return new_infl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3e5bef79",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████| 13264/13264 [00:16<00:00, 827.38it/s]\n"
     ]
    }
   ],
   "source": [
    "new_infl = []\n",
    "df_edge_copy = df_edge.copy()\n",
    "for i in tqdm(range(len(df_edge))):\n",
    "    f = df_edge.loc[i, ['from_edges']].values[0]\n",
    "    t = df_edge.loc[i, ['to_edges']].values[0]\n",
    "    \n",
    "    act_1 = df_edge[(df_edge['from_edges'] == f) & (df_edge['to_edges'] == t)].actual_influence.values[0]\n",
    "    act_2 = df_edge[(df_edge['from_edges'] == t) & (df_edge['to_edges'] == f)].actual_influence.values[0]\n",
    "    new_infl.append((act_1 + act_2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9db870d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_copy['influence'] = new_infl\n",
    "df_edge_preprocessed = df_edge_copy.drop(columns=['actual_influence', 'predicted_influence'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "887dc3a5",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed = df_edge_preprocessed.sort_values(['influence'], ascending=False)\n",
    "df_edge_preprocessed.index = range(len(df_edge_preprocessed))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1fe04582",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_edge_preprocessed_0 = df_edge_preprocessed.copy()\n",
    "# for i in tqdm(range(len(df_edge_preprocessed))):\n",
    "#     src = df_edge_preprocessed.loc[i, ['from_edges']].values[0].astype(int)\n",
    "#     dst = df_edge_preprocessed.loc[i, ['to_edges']].values[0].astype(int)\n",
    "#     index_temp = df_edge_preprocessed[(df_edge_preprocessed['from_edges'] == dst) & \n",
    "#                      (df_edge_preprocessed['to_edges'] == src)].index[0]\n",
    "#     if index_temp:\n",
    "#         df_edge_preprocessed_0 = df_edge_preprocessed_0.drop([index_temp])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "11729aba",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed_0 = df_edge_preprocessed.copy()\n",
    "df_edge_preprocessed_0 = df_edge_preprocessed_0.drop_duplicates(subset = ['influence'])\n",
    "df_edge_preprocessed_0['from_edges'] = df_edge_preprocessed_0['from_edges'].astype(int).values\n",
    "df_edge_preprocessed_0['to_edges'] = df_edge_preprocessed_0['to_edges'].astype(int).values\n",
    "df_edge_preprocessed_0.index = range(len(df_edge_preprocessed_0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "2309b595",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_edge_preprocessed[(df_edge_preprocessed['from_edges'] == dst) & \n",
    "#                      (df_edge_preprocessed['to_edges'] == src)].index[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "fb0467fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th>influence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5851</th>\n",
       "      <td>2707.0</td>\n",
       "      <td>2706.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6874</th>\n",
       "      <td>2707.0</td>\n",
       "      <td>2707.0</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      from_edges  to_edges  influence\n",
       "5851      2707.0    2706.0        0.0\n",
       "6874      2707.0    2707.0        0.0"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge_preprocessed[df_edge_preprocessed['from_edges']  == 2707 ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "2c1e9429",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed.to_csv('df_edge_preprocessed_0.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f6bc03e2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19d990a7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23189c44",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "7566fa4f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th>influence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "Empty DataFrame\n",
       "Columns: [from_edges, to_edges, influence]\n",
       "Index: []"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge_preprocessed_0[df_edge_preprocessed_0['from_edges']  == 2707 ]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "811bc2dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th>actual_influence</th>\n",
       "      <th>predicted_influence</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th rowspan=\"5\" valign=\"top\">0.0</th>\n",
       "      <th>0.0</th>\n",
       "      <td>-0.003535</td>\n",
       "      <td>-0.009597</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1.0</th>\n",
       "      <td>-0.041388</td>\n",
       "      <td>-0.039180</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2.0</th>\n",
       "      <td>-0.065856</td>\n",
       "      <td>-0.004634</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3.0</th>\n",
       "      <td>-0.002741</td>\n",
       "      <td>0.005007</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5.0</th>\n",
       "      <td>0.025395</td>\n",
       "      <td>0.007271</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2705.0</th>\n",
       "      <th>2705.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">2706.0</th>\n",
       "      <th>2706.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2707.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th rowspan=\"2\" valign=\"top\">2707.0</th>\n",
       "      <th>2706.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2707.0</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>13264 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                     actual_influence  predicted_influence\n",
       "from_edges to_edges                                       \n",
       "0.0        0.0              -0.003535            -0.009597\n",
       "           1.0              -0.041388            -0.039180\n",
       "           2.0              -0.065856            -0.004634\n",
       "           3.0              -0.002741             0.005007\n",
       "           5.0               0.025395             0.007271\n",
       "...                               ...                  ...\n",
       "2705.0     2705.0            0.000000             0.000000\n",
       "2706.0     2706.0            0.000000             0.000000\n",
       "           2707.0            0.000000             0.000000\n",
       "2707.0     2706.0            0.000000             0.000000\n",
       "           2707.0            0.000000             0.000000\n",
       "\n",
       "[13264 rows x 2 columns]"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge_influence"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "3571ef23",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>actual influence</th>\n",
       "      <th>node_id</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>9.570093</td>\n",
       "      <td>1281</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "    actual influence  node_id\n",
       "14          9.570093     1281"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_node_preprocessed.loc[df_node_preprocessed['node_id'] == 1281]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4dc1b0e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed_1 = df_edge_preprocessed_0.copy()\n",
    "f_node_infl = []\n",
    "t_node_infl = []\n",
    "\n",
    "node_ids_temp = df_node_preprocessed['node_id'].values\n",
    "for i in range(len(df_edge_preprocessed_0)):\n",
    "    f_temp_node = df_edge_preprocessed_0.loc[i, ['from_edges']].values[0].astype(int)\n",
    "    t_temp_node = df_edge_preprocessed_0.loc[i, ['to_edges']].values[0].astype(int)\n",
    "\n",
    "    \n",
    "    if f_temp_node in node_ids_temp:\n",
    "        temp_infl_node = df_node_preprocessed.loc[df_node_preprocessed['node_id'] == f_temp_node, \n",
    "                                                  ['actual influence']].values[0][0]\n",
    "        \n",
    "        f_current_node_infl = temp_infl_node\n",
    "    else:\n",
    "        f_current_node_infl = 0.0\n",
    "    \n",
    "    f_node_infl.append(f_current_node_infl)\n",
    "\n",
    "\n",
    "    if t_temp_node in node_ids_temp:\n",
    "        temp_infl_node = df_node_preprocessed.loc[df_node_preprocessed['node_id'] == t_temp_node, \n",
    "                                                  ['actual influence']].values[0][0]\n",
    "        \n",
    "        t_current_node_infl = temp_infl_node\n",
    "    else:\n",
    "        t_current_node_infl = 0.0\n",
    "\n",
    "    t_node_infl.append(t_current_node_infl)\n",
    "    \n",
    "    \n",
    "\n",
    "# df_edge_preprocessed_1['src_node_influence'] = f_node_infl\n",
    "# df_edge_preprocessed_1['dst_node_influence'] = t_node_infl\n",
    "df_edge_preprocessed_1['src_node_influence'] = np.array(f_node_infl) - min(f_node_infl) + 1\n",
    "df_edge_preprocessed_1['dst_node_influence'] = np.array(t_node_infl) - min(t_node_infl) + 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2405fc47",
   "metadata": {},
   "outputs": [],
   "source": [
    "# labels[df_edge_preprocessed_2['from_edges'].values]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "069b95b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed_2 = df_edge_preprocessed_1.copy()\n",
    "label_list_f = []\n",
    "label_list_t = []\n",
    "# labels = labels.numpy()\n",
    "for i in range(len(df_edge_preprocessed_1)):\n",
    "    f_id = df_edge_preprocessed_1.loc[i, ['from_edges']].values[0]\n",
    "    f_id = int(f_id)\n",
    "    f_c = labels[f_id]\n",
    "    label_list_f.append(f_c)\n",
    "    \n",
    "    \n",
    "    t_id = df_edge_preprocessed_1.loc[i, ['to_edges']].values[0]\n",
    "    t_id = int(t_id)\n",
    "    t_c = labels[t_id]\n",
    "    label_list_t.append(t_c)\n",
    "df_edge_preprocessed_2['from_node_labels'] = label_list_f\n",
    "df_edge_preprocessed_2['to_node_labels'] = label_list_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "54db406a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# test_mask = test_mask.numpy()\n",
    "val_mask = val_mask.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "32f7d9f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed_3 = df_edge_preprocessed_2.copy()\n",
    "# 0: train, 1:test, 2:\n",
    "train_or_test_list_f = []\n",
    "train_or_test_list_t = []\n",
    "\n",
    "for i in range(len(df_edge_preprocessed_2)):\n",
    "    f_id = df_edge_preprocessed_1.loc[i, ['from_edges']].values[0]\n",
    "    f_id = int(f_id)\n",
    "    t_id = df_edge_preprocessed_1.loc[i, ['to_edges']].values[0]\n",
    "    t_id = int(t_id)\n",
    "    \n",
    "    if train_mask[f_id]:\n",
    "        train_or_test_list_f.append(0)\n",
    "    elif test_mask[f_id]:\n",
    "        train_or_test_list_f.append(1)\n",
    "    else:\n",
    "        train_or_test_list_f.append(2)\n",
    "        \n",
    "    if train_mask[t_id]:\n",
    "        train_or_test_list_t.append(0)\n",
    "    elif test_mask[t_id]:\n",
    "        train_or_test_list_t.append(1)\n",
    "    else:\n",
    "        train_or_test_list_t.append(2)\n",
    "\n",
    "df_edge_preprocessed_3['from_node_train_test'] = train_or_test_list_f\n",
    "df_edge_preprocessed_3['to_node_train_test'] = train_or_test_list_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b78e11f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "031d58ed",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th>influence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>1281.0</td>\n",
       "      <td>2.605583</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>132</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>2014.0</td>\n",
       "      <td>0.344481</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>437</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>1797.0</td>\n",
       "      <td>0.136648</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>784</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>2013.0</td>\n",
       "      <td>0.084075</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>818</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>1280.0</td>\n",
       "      <td>0.080981</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9198</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>1848.0</td>\n",
       "      <td>-0.021757</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13049</th>\n",
       "      <td>2014.0</td>\n",
       "      <td>2419.0</td>\n",
       "      <td>-0.183339</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       from_edges  to_edges  influence\n",
       "1          2014.0    1281.0   2.605583\n",
       "132        2014.0    2014.0   0.344481\n",
       "437        2014.0    1797.0   0.136648\n",
       "784        2014.0    2013.0   0.084075\n",
       "818        2014.0    1280.0   0.080981\n",
       "9198       2014.0    1848.0  -0.021757\n",
       "13049      2014.0    2419.0  -0.183339"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge_preprocessed.loc[df_edge_preprocessed['from_edges'] == 2014]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "af0de70f",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = dgl.graph(([1, 1, 2, 3, 4], [0, 2, 0, 4, 2]))\n",
    "g0 = dgl.to_networkx(g)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c17a3a69",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>actual influence</th>\n",
       "      <th>node_id</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>15.530282</td>\n",
       "      <td>2079</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>14.665039</td>\n",
       "      <td>1879</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>13.158551</td>\n",
       "      <td>2367</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>12.499614</td>\n",
       "      <td>1716</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>12.212362</td>\n",
       "      <td>1793</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>135</th>\n",
       "      <td>-1.322061</td>\n",
       "      <td>2209</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>136</th>\n",
       "      <td>-1.688545</td>\n",
       "      <td>2658</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>137</th>\n",
       "      <td>-1.981031</td>\n",
       "      <td>542</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>138</th>\n",
       "      <td>-3.037878</td>\n",
       "      <td>138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>139</th>\n",
       "      <td>-4.082214</td>\n",
       "      <td>432</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>140 rows × 2 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     actual influence  node_id\n",
       "0           15.530282     2079\n",
       "1           14.665039     1879\n",
       "2           13.158551     2367\n",
       "3           12.499614     1716\n",
       "4           12.212362     1793\n",
       "..                ...      ...\n",
       "135         -1.322061     2209\n",
       "136         -1.688545     2658\n",
       "137         -1.981031      542\n",
       "138         -3.037878      138\n",
       "139         -4.082214      432\n",
       "\n",
       "[140 rows x 2 columns]"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_node_preprocessed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "4157aa30",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_ede"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "9593a382",
   "metadata": {},
   "outputs": [],
   "source": [
    "def neighbors_df(df, node_id):\n",
    "    pass"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2fd0c02e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th>influence</th>\n",
       "      <th>src_node_influence</th>\n",
       "      <th>dst_node_influence</th>\n",
       "      <th>from_node_labels</th>\n",
       "      <th>to_node_labels</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3231</th>\n",
       "      <td>1879</td>\n",
       "      <td>1060</td>\n",
       "      <td>-0.020915</td>\n",
       "      <td>19.747253</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5327</th>\n",
       "      <td>1879</td>\n",
       "      <td>2326</td>\n",
       "      <td>-0.140576</td>\n",
       "      <td>19.747253</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(4)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5417</th>\n",
       "      <td>1879</td>\n",
       "      <td>1059</td>\n",
       "      <td>-0.182723</td>\n",
       "      <td>19.747253</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5486</th>\n",
       "      <td>1879</td>\n",
       "      <td>1879</td>\n",
       "      <td>-0.263894</td>\n",
       "      <td>19.747253</td>\n",
       "      <td>19.747253</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      from_edges  to_edges  influence  src_node_influence  dst_node_influence  \\\n",
       "3231        1879      1060  -0.020915           19.747253            5.082214   \n",
       "5327        1879      2326  -0.140576           19.747253            5.082214   \n",
       "5417        1879      1059  -0.182723           19.747253            5.082214   \n",
       "5486        1879      1879  -0.263894           19.747253           19.747253   \n",
       "\n",
       "     from_node_labels to_node_labels  \n",
       "3231        tensor(3)      tensor(3)  \n",
       "5327        tensor(3)      tensor(4)  \n",
       "5417        tensor(3)      tensor(3)  \n",
       "5486        tensor(3)      tensor(3)  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# df_edge_preprocessed_2.to_csv('temp_visulization.csv', index = False)\n",
    "df_edge_preprocessed_2.loc[df_edge_preprocessed_2['from_edges'] == 1879]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "0ad3e69c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1293"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(df_edge_preprocessed_2['from_node_labels'] == 3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "3ea21d31",
   "metadata": {},
   "outputs": [],
   "source": [
    "color_plate = ['pink', 'olive', 'Green','Cyan','Magenta','Yellow', 'Brown', 'Violet']\n",
    "color_plate_edge = ['Red','Blue','black']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "2c0ab8ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visulize_v1(df_node, df_edge, height='750px', width='100%', bgcolor='#ffffff', font_color=False):\n",
    "    \n",
    "    got_net = Network(height=height, width=width, bgcolor = bgcolor, font_color=font_color)\n",
    "    \n",
    "    \n",
    "    for i in range(len(df_edge)):\n",
    "        src = df_edge.loc[i, ['from_edges']].values[0]\n",
    "        src = int(src)\n",
    "        \n",
    "        dst = df_edge.loc[i, ['to_edges']].values[0]\n",
    "        dst = int(dst)\n",
    "        \n",
    "        \n",
    "        src_color = df_edge.loc[i, ['from_node_labels']].values[0]\n",
    "        src_color = int(src_color)\n",
    "#         print(src_color)\n",
    "        dst_color = df_edge.loc[i, ['to_node_labels']].values[0]\n",
    "        dst_color = int(dst_color)\n",
    "        \n",
    "        \n",
    "        src_infl = df_edge.loc[i, ['src_node_influence']].values[0]\n",
    "        src_infl = float(src_infl)\n",
    "        \n",
    "        dst_infl = df_edge.loc[i, ['dst_node_influence']].values[0]\n",
    "        dst_infl = float(dst_infl)\n",
    "        \n",
    "        \n",
    "        edge_infl = df_edge.loc[i, ['influence']].values[0].astype(float)\n",
    "        \n",
    "        got_net.add_node(n_id = src, title=str(src), size = src_infl, color = color_plate[src_color])\n",
    "        got_net.add_node(n_id = dst, title=str(dst), size = dst_infl, color = color_plate[dst_color])\n",
    "        \n",
    "        got_net.add_edge(src, dst, value=edge_infl)\n",
    "        \n",
    "    got_net.show('graph_influence.html')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "773ffffe",
   "metadata": {},
   "outputs": [],
   "source": [
    "color_plate = ['pink', 'olive', 'Green','Cyan','Magenta','Yellow', 'Brown', 'Violet']\n",
    "color_plate_edge = ['Red','Blue','black']\n",
    "# type_plate = [\"octagon\", \"X\", \"^\"]\n",
    "type_plate = ['dot', 'star', 'diamond']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "8aec23ab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_mask[2367]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "85273ae2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>from_edges</th>\n",
       "      <th>to_edges</th>\n",
       "      <th>influence</th>\n",
       "      <th>src_node_influence</th>\n",
       "      <th>dst_node_influence</th>\n",
       "      <th>from_node_labels</th>\n",
       "      <th>to_node_labels</th>\n",
       "      <th>from_node_train_test</th>\n",
       "      <th>to_node_train_test</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1281</td>\n",
       "      <td>2014</td>\n",
       "      <td>2.605583</td>\n",
       "      <td>14.652306</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(0)</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1152</td>\n",
       "      <td>554</td>\n",
       "      <td>2.116021</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>14.878215</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1082</td>\n",
       "      <td>1082</td>\n",
       "      <td>1.797256</td>\n",
       "      <td>5.413330</td>\n",
       "      <td>5.413330</td>\n",
       "      <td>tensor(6)</td>\n",
       "      <td>tensor(6)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>741</td>\n",
       "      <td>741</td>\n",
       "      <td>1.566844</td>\n",
       "      <td>5.069208</td>\n",
       "      <td>5.069208</td>\n",
       "      <td>tensor(1)</td>\n",
       "      <td>tensor(1)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2297</td>\n",
       "      <td>1857</td>\n",
       "      <td>1.551643</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(5)</td>\n",
       "      <td>1</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5561</th>\n",
       "      <td>1857</td>\n",
       "      <td>1857</td>\n",
       "      <td>-0.993066</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>5.082214</td>\n",
       "      <td>tensor(5)</td>\n",
       "      <td>tensor(5)</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5562</th>\n",
       "      <td>2367</td>\n",
       "      <td>2367</td>\n",
       "      <td>-1.024753</td>\n",
       "      <td>18.240765</td>\n",
       "      <td>18.240765</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5563</th>\n",
       "      <td>79</td>\n",
       "      <td>79</td>\n",
       "      <td>-1.777368</td>\n",
       "      <td>8.876181</td>\n",
       "      <td>8.876181</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5564</th>\n",
       "      <td>554</td>\n",
       "      <td>554</td>\n",
       "      <td>-2.366645</td>\n",
       "      <td>14.878215</td>\n",
       "      <td>14.878215</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5565</th>\n",
       "      <td>1049</td>\n",
       "      <td>1049</td>\n",
       "      <td>-2.785466</td>\n",
       "      <td>13.272417</td>\n",
       "      <td>13.272417</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>tensor(3)</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5566 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      from_edges  to_edges  influence  src_node_influence  dst_node_influence  \\\n",
       "0           1281      2014   2.605583           14.652306            5.082214   \n",
       "1           1152       554   2.116021            5.082214           14.878215   \n",
       "2           1082      1082   1.797256            5.413330            5.413330   \n",
       "3            741       741   1.566844            5.069208            5.069208   \n",
       "4           2297      1857   1.551643            5.082214            5.082214   \n",
       "...          ...       ...        ...                 ...                 ...   \n",
       "5561        1857      1857  -0.993066            5.082214            5.082214   \n",
       "5562        2367      2367  -1.024753           18.240765           18.240765   \n",
       "5563          79        79  -1.777368            8.876181            8.876181   \n",
       "5564         554       554  -2.366645           14.878215           14.878215   \n",
       "5565        1049      1049  -2.785466           13.272417           13.272417   \n",
       "\n",
       "     from_node_labels to_node_labels  from_node_train_test  to_node_train_test  \n",
       "0           tensor(3)      tensor(0)                     0                   1  \n",
       "1           tensor(3)      tensor(3)                     1                   0  \n",
       "2           tensor(6)      tensor(6)                     0                   0  \n",
       "3           tensor(1)      tensor(1)                     0                   0  \n",
       "4           tensor(3)      tensor(5)                     1                   2  \n",
       "...               ...            ...                   ...                 ...  \n",
       "5561        tensor(5)      tensor(5)                     2                   2  \n",
       "5562        tensor(3)      tensor(3)                     0                   0  \n",
       "5563        tensor(3)      tensor(3)                     0                   0  \n",
       "5564        tensor(3)      tensor(3)                     0                   0  \n",
       "5565        tensor(3)      tensor(3)                     0                   0  \n",
       "\n",
       "[5566 rows x 9 columns]"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge_preprocessed_3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "9c1156c7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_edge_preprocessed_3.to_csv('df_edge_preprocessed_3.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "a2ea0ea7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_node_preprocessed.to_csv('df_node_preprocessed.csv', index = False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "4773f06a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visulize_v2(df_node, df_edge, height='750px', width='100%', bgcolor='#ffffff', \n",
    "                font_color=False, bar_infl_edge = 0.09):\n",
    "    \n",
    "    got_net = Network(height=height, width=width, bgcolor = bgcolor, font_color=font_color)\n",
    "    \n",
    "    \n",
    "    for i in range(len(df_edge)):\n",
    "        src = df_edge.loc[i, ['from_edges']].values[0]\n",
    "        src = int(src)\n",
    "        \n",
    "        dst = df_edge.loc[i, ['to_edges']].values[0]\n",
    "        dst = int(dst)\n",
    "        \n",
    "        \n",
    "        src_color = df_edge.loc[i, ['from_node_labels']].values[0]\n",
    "        src_color = int(src_color)\n",
    "#         print(src_color)\n",
    "        dst_color = df_edge.loc[i, ['to_node_labels']].values[0]\n",
    "        dst_color = int(dst_color)\n",
    "        \n",
    "        \n",
    "        src_infl = df_edge.loc[i, ['src_node_influence']].values[0]\n",
    "        src_infl = float(src_infl)\n",
    "        \n",
    "        dst_infl = df_edge.loc[i, ['dst_node_influence']].values[0]\n",
    "        dst_infl = float(dst_infl)\n",
    "        \n",
    "        \n",
    "        edge_infl = df_edge.loc[i, ['influence']].values[0].astype(float)\n",
    "        \n",
    "        \n",
    "        src_train_test = df_edge.loc[i, ['from_node_train_test']].values[0]\n",
    "        src_train_test = int(src_train_test)\n",
    "        \n",
    "        dst_train_test = df_edge.loc[i, ['to_node_train_test']].values[0]\n",
    "        dst_train_test = int(src_train_test)\n",
    "        \n",
    "        \n",
    "        if edge_infl >= bar_infl_edge:\n",
    "            color_edge = color_plate_edge[0]\n",
    "            value_edge = abs(edge_infl)\n",
    "            \n",
    "        elif (edge_infl >= 0) and (edge_infl < bar_infl_edge):\n",
    "            color_edge = color_plate_edge[2]\n",
    "            value_edge = abs(edge_infl) + 0.1\n",
    "        else:\n",
    "            color_edge = color_plate_edge[1]\n",
    "            value_edge = abs(edge_infl)\n",
    "        \n",
    "        \n",
    "        if src_train_test == 0:\n",
    "            src_node_type = type_plate[0]\n",
    "        elif src_train_test == 1:\n",
    "            src_node_type = type_plate[1]\n",
    "        else:\n",
    "            src_node_type = type_plate[2]\n",
    "            \n",
    "        if dst_train_test == 0:\n",
    "            dst_node_type = type_plate[0]\n",
    "        elif dst_train_test == 1:\n",
    "            dst_node_type = type_plate[1]\n",
    "        else:\n",
    "            dst_node_type = type_plate[2]\n",
    "            \n",
    "#         print(src_node_type)\n",
    "#         got_net.add_node(n_id = src, title=str(src), size = src_infl, color = color_plate[src_color])\n",
    "#         got_net.add_node(n_id = dst, title=str(dst), size = dst_infl, color = color_plate[dst_color])\n",
    "        got_net.add_node(n_id = src, title=str(src), size = src_infl, \n",
    "                         color = color_plate[src_color], shape = src_node_type)\n",
    "        got_net.add_node(n_id = dst, title=str(dst), size = dst_infl, \n",
    "                         color = color_plate[dst_color], shape = dst_node_type)\n",
    "        \n",
    "        got_net.add_edge(src, dst, value=value_edge, color = color_edge)\n",
    "        \n",
    "    got_net.show('graph_influence_v2.html')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "2601b443",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df_edge_preprocessed_2.loc[:, ['influence']].values[0].astype(float)\n",
    "edge_infl_array = df_edge_preprocessed_2.loc[:, ['influence']].values.astype(float).reshape(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "4e6bdbb7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.07411980334984485"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.quantile(edge_infl_array, 0.9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "583f7880",
   "metadata": {},
   "outputs": [],
   "source": [
    "visulize_v2(df_node_feature, df_edge_preprocessed_3[0:1000])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "a45f1c30",
   "metadata": {},
   "outputs": [],
   "source": [
    "visulize_v1(df_node_feature, df_edge_preprocessed_2[0:1000])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "f9c07775",
   "metadata": {},
   "outputs": [],
   "source": [
    "visulize_v1(df_node_feature, df_edge_preprocessed_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "c74a298c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# visulize_v1(df_node_feature, df_edge_preprocessed_3)\n",
    "visulize_v2(df_node_feature, df_edge_preprocessed_3, bar_infl_edge = 0.00)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "b6776c84",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "953"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_edge.loc[i, ['from_edges']].values[0].astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "993fb831",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "isinstance(int(df_edge.loc[i, ['from_edges']].values[0]), int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "37db9766",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Jy8vD4BGjRoxceJELrnkErKzs9m5c+cx+5k0aRKjRo3iu+++q+khiIiHIg4C59whYBzwBvAxsMA5t8nMxprZ2ECzJcBWYAswE7j1eNtG2qfa9MknnzBmzBgKCgr4/ve/z1NPPXVU/b59+8jOzuajjz6iW7duzJw586j68ePH88UXXzBr1izi4vSYh4jEXjQuDeGcW0LZf/bly6aXe+2An4e7bX3WqlUrunTpAsDw4cN54oknjqpPSEhg4MCBAHTo0IGlS5cG637zm9/QqVMnZsyYUXMdFhHv6SNnlJnZcddPOeWUYFl8fDyHDv33vkTHjh3Jz8/n3//+d+w7KiIS4GcQnFLJiVBl5VWwbds23n//fQDmzZtH165dw962X79+TJgwgSuuuIK9e/dG3BcRkXBE5dJQvdM5LWa7vuiii5gzZw4/+9nPaNOmDbfccguLFy8Oe/shQ4awd+9eBg0axJIlSzjttNNi1lcREQAru3xfv2RmZroj38KpS4qLixk4cCAbN26s7a6IiBzDzPKdc5kVy/28NCQiIkEKgihKTk7W2YCI1DsKAhERzykIREQ8pyAQEfGcgkBExHNePkcwefK57Nt37GRviYlNueuuz6N6rEaNGvH111+zfft2br/9dk01LSJ1jpdnBKFC4Hjl0dC8eXOFgIjUSV4GQaw89thjtG/fnvbt2zNlypSj6oqLi2nfvj0AnTp1YtOm/06y2r17d/Lz89m3bx8333wzHTt2JD09nVdffbUmuy8inlIQREl+fj6zZs3igw8+YPXq1cycOZN169aFbDt06FAWLFgAwI4dO9i+fTsdOnTgwQcfpEePHqxZs4Zly5Zx9913s2/fvpochoh4SEEQJStWrOCaa64hMTGRRo0ace2117J8+fKQba+77jr++te/ArBgwQKGDBkCwJtvvslDDz1EWloa3bt3p7S0lG3bttXYGETET17eLI6FqszZ1KJFC84++2wKCgp44YUXePrpp4P7WLhwIRdeeGGsuikicgwvzwgSE5tWqTwc3bp145VXXmH//v3s27ePl19+mZycnErbDx06lEceeYQ9e/aQkpICQN++fXnyySeDoVLZpSURkWjy8owg2l8RBcjIyGDUqFFkZWUBMHr0aNLT0yttP3jwYO644w4mTZoULJs0aRK/+MUvSE1NxTlHcnIyr732WtT7KiJSnqah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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "colors = ['pink', 'olive', 'Green','Cyan','Magenta','Yellow', 'Brown']\n",
    "f = lambda m,c: plt.plot([],[],marker=m, color=c, ls=\"none\")[0]\n",
    "handles = [f(\"s\", colors[i]) for i in range(7)]\n",
    "labels = colors\n",
    "legend = plt.legend(handles, labels, loc=3, framealpha=1, frameon=False)\n",
    "\n",
    "def export_legend(legend, filename=\"legend.png\"):\n",
    "    fig  = legend.figure\n",
    "    fig.canvas.draw()\n",
    "    bbox  = legend.get_window_extent().transformed(fig.dpi_scale_trans.inverted())\n",
    "    fig.savefig(filename, dpi=\"figure\", bbox_inches=bbox)\n",
    "\n",
    "export_legend(legend)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "593f9abb",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_36167/287126257.py:7: UserWarning: Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n",
      "  fig.show()\n",
      "/tmp/ipykernel_36167/287126257.py:8: UserWarning: Matplotlib is currently using module://matplotlib_inline.backend_inline, which is a non-GUI backend, so cannot show the figure.\n",
      "  figlegend.show()\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 216x144 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pylab\n",
    "fig = pylab.figure()\n",
    "figlegend = pylab.figure(figsize=(3,2))\n",
    "ax = fig.add_subplot(111)\n",
    "lines = ax.plot(range(10), pylab.randn(10), range(10), pylab.randn(10))\n",
    "figlegend.legend(lines, ('one', 'two'), 'center')\n",
    "fig.show()\n",
    "figlegend.show()\n",
    "figlegend.savefig('legend.png')"
   ]
  }
 ],
 "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
}
