{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "54939b34",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import scipy.stats\n",
    "from typing import Sequence\n",
    "import numpy as np\n",
    "from matplotlib.ticker import (AutoMinorLocator, MultipleLocator)\n",
    "from dataset import load_graph_dataset\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "25ce9520",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\n",
      "  NumValidationSamples: 500\n",
      "  NumTestSamples: 1000\n",
      "Done loading data from cached files.\n"
     ]
    }
   ],
   "source": [
    "# font_size = 12\n",
    "# loss_threshold = 0.01\n",
    "# y_lab_xcoordinate = -0.25\n",
    "\n",
    "graph, feat, labels, train_mask, val_mask, test_mask, number_classes = load_graph_dataset('citeseer')\n",
    "df1 = pd.read_csv('citeseer_theory/citeseer_edge_influence_0.1.csv', header = None)\n",
    "df1 = df0.loc[df0[0]!= 0, ]\n",
    "f_l = df1[2].values.astype(int)\n",
    "t_l = df1[3].values.astype(int)\n",
    "\n",
    "degree_list = np.array([np.array(graph.in_degrees(f_l[i])) + np.array(graph.in_degrees(t_l[i])) for i in range(len(f_l))])\n",
    "df1['degree'] = degree_list\n",
    "\n",
    "degree_threshold = np.quantile(degree_list, 0.90)\n",
    "\n",
    "degree_labels1 = np.array(degree_list > degree_threshold).astype(int)\n",
    "df1['degree_labels'] = degree_labels1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "780111ec",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(6646,)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "degree_labels1_notzero = degree_labels1[df1[0]!= 0]\n",
    "degree_labels1_notzero.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b48eaa8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>degree</th>\n",
       "      <th>degree_labels</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>5245</th>\n",
       "      <td>-0.194921</td>\n",
       "      <td>-0.132504</td>\n",
       "      <td>1896.0</td>\n",
       "      <td>72.0</td>\n",
       "      <td>24</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>215</th>\n",
       "      <td>-0.194921</td>\n",
       "      <td>-0.132504</td>\n",
       "      <td>72.0</td>\n",
       "      <td>1896.0</td>\n",
       "      <td>24</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2809</th>\n",
       "      <td>-0.149954</td>\n",
       "      <td>-0.082143</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>9.0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>-0.149954</td>\n",
       "      <td>-0.082143</td>\n",
       "      <td>9.0</td>\n",
       "      <td>1007.0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>202</th>\n",
       "      <td>-0.148159</td>\n",
       "      <td>-0.110157</td>\n",
       "      <td>68.0</td>\n",
       "      <td>2411.0</td>\n",
       "      <td>7</td>\n",
       "      <td>0</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5616</th>\n",
       "      <td>0.166801</td>\n",
       "      <td>0.094360</td>\n",
       "      <td>2034.0</td>\n",
       "      <td>11.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>0.180022</td>\n",
       "      <td>0.126843</td>\n",
       "      <td>18.0</td>\n",
       "      <td>812.0</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2271</th>\n",
       "      <td>0.180022</td>\n",
       "      <td>0.126843</td>\n",
       "      <td>812.0</td>\n",
       "      <td>18.0</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8939</th>\n",
       "      <td>0.183920</td>\n",
       "      <td>0.167051</td>\n",
       "      <td>3237.0</td>\n",
       "      <td>46.0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>137</th>\n",
       "      <td>0.183920</td>\n",
       "      <td>0.167051</td>\n",
       "      <td>46.0</td>\n",
       "      <td>3237.0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6646 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0         1       2       3  degree  degree_labels\n",
       "5245 -0.194921 -0.132504  1896.0    72.0      24              0\n",
       "215  -0.194921 -0.132504    72.0  1896.0      24              0\n",
       "2809 -0.149954 -0.082143  1007.0     9.0       5              0\n",
       "16   -0.149954 -0.082143     9.0  1007.0       5              0\n",
       "202  -0.148159 -0.110157    68.0  2411.0       7              0\n",
       "...        ...       ...     ...     ...     ...            ...\n",
       "5616  0.166801  0.094360  2034.0    11.0       4              0\n",
       "56    0.180022  0.126843    18.0   812.0       9              0\n",
       "2271  0.180022  0.126843   812.0    18.0       9              0\n",
       "8939  0.183920  0.167051  3237.0    46.0       5              0\n",
       "137   0.183920  0.167051    46.0  3237.0       5              0\n",
       "\n",
       "[6646 rows x 6 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df1.sort_values(by=[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "bcb58575",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df0.shape, df2.shape, df1.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "28c374ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cal_percent_error(df, degree_labels1_notzero):\n",
    "    all_perentage_error = np.array(df[1].values - df[0].values) / df[0].values\n",
    "    all_perentage_error = np.abs(all_perentage_error)\n",
    "    return np.mean(all_perentage_error[degree_labels1_notzero]), np.mean(all_perentage_error[1- degree_labels1_notzero])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "365dc242",
   "metadata": {},
   "outputs": [],
   "source": [
    "color_plate = ['royalblue', 'darkorange']\n",
    "\n",
    "df0 = pd.read_csv('citeseer_theory/citeseer_edge_influence_0.1.csv', header = None)\n",
    "df0 = df0.loc[df0[0]!= 0, ]\n",
    "df0.index = range(len(df0))\n",
    "df1 = pd.read_csv('citeseer_theory/citeseer_edge_influence_0.01.csv', header = None)\n",
    "df1 = df1.loc[df1[0]!= 0, ]\n",
    "df1.index = range(len(df1))\n",
    "df2 = pd.read_csv('citeseer_theory/citeseer_edge_influence_001.csv', header = None)\n",
    "df2 = df2.loc[df2[0]!= 0, ]\n",
    "df2.index = range(len(df2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "173118f1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  NumNodes: 3327\n",
      "  NumEdges: 9228\n",
      "  NumFeats: 3703\n",
      "  NumClasses: 6\n",
      "  NumTrainingSamples: 120\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('citeseer')\n",
    "df2 = pd.read_csv('citeseer_theory/citeseer_edge_influence_001.csv', header = None)\n",
    "df2 = df2.loc[df2[0]!= 0, ]\n",
    "df2.index = range(len(df2))\n",
    "f_l = df2[2].values.astype(int)\n",
    "t_l = df2[3].values.astype(int)\n",
    "\n",
    "degree_list_2 = np.array([np.array(graph.in_degrees(f_l[i])) + np.array(graph.in_degrees(t_l[i])) for i in range(len(f_l))])\n",
    "df2['degree'] = degree_list_2\n",
    "\n",
    "degree_threshold = np.quantile(degree_list, 0.90)\n",
    "\n",
    "degree_labels2 = np.array(degree_list_2 > degree_threshold).astype(int)\n",
    "df2['degree_labels'] = degree_labels2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "499a1ac3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_edge(df, ax, i, plot_label = False, sep = 5, xlab_name = '', ylab_name = '', \n",
    "                      low_limit = -4.5, up_limit = 4.5, temp_x_ticks = [-3, -1.5, 0, 1.5, 3], \n",
    "                  font_size = 12, loss_threshold = 0.01, y_lab_xcoordinate = -0.25, degree_labels = degree_labels1, \n",
    "                  title_a = ''):\n",
    "    acctual_influence_1 = df[0].values\n",
    "    predict_influence_1 = df[1].values\n",
    "#     low_limit = -np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.5\n",
    "#     up_limit = np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.5\n",
    "    \n",
    "#     print(low_limit)\n",
    "#     print(up_limit)\n",
    "#     low_limit = -8.194854476955078\n",
    "#     up_limit = 8.194854476955078\n",
    "    low_limit = low_limit\n",
    "    up_limit = up_limit\n",
    "    corr = np.zeros(2)\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"white\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    for g in np.unique(degree_labels):\n",
    "        idx = np.where(degree_labels == g)\n",
    "#         print(g)\n",
    "        ax[i].scatter(acctual_influence_1[idx], predict_influence_1[idx], s = 20, \n",
    "                      label = degree_labels, linewidths=0, color = color_plate[g])\n",
    "        \n",
    "        corr[g] = np.round(scipy.stats.pearsonr(acctual_influence_1[idx], predict_influence_1[idx])[0], 3)\n",
    "        \n",
    "    ax[i].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i].axis('square')\n",
    "    if plot_label:\n",
    "        ax[i].set_ylabel('Pred. Influence')\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax[i].set_ylim(low_limit, up_limit)\n",
    "    ax[i].set_xlim(low_limit, up_limit)\n",
    "    \n",
    "    grid_x_ticks = np.arange(low_limit, up_limit, (up_limit - low_limit) / sep)\n",
    "    grid_y_ticks = np.arange(low_limit, up_limit, (up_limit - low_limit) / sep)\n",
    "\n",
    "    ax[i].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i].set_xticks(temp_x_ticks)\n",
    "    ax[i].set_yticks(grid_y_ticks , minor=True)\n",
    "    ax[i].set_yticks(temp_x_ticks)\n",
    "\n",
    "    ax[i].grid(which='both')\n",
    "\n",
    "    ax[i].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    ax[i].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    \n",
    "    a = np.array(acctual_influence_1)\n",
    "    a = np.around(a, 5)\n",
    "    b = np.array(predict_influence_1)\n",
    "    b = np.around(b, 5)\n",
    "    index_ = np.intersect1d(np.where(np.abs(a) > loss_threshold)[0], np.where(np.abs(b) > loss_threshold)[0])\n",
    "    \n",
    "    new_degree_labels = degree_labels[index_]\n",
    "    \n",
    "    a = a[index_]\n",
    "    b = b[index_]\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1[index_], predict_influence_1[index_])[0], 3)\n",
    "    \n",
    "    for g in np.unique(new_degree_labels):\n",
    "        idx_new = np.where(new_degree_labels == g)\n",
    "\n",
    "        \n",
    "        corr[g] = np.round(scipy.stats.spearmanr(a[idx_new], b[idx_new])[0], 3)\n",
    "    \n",
    "    corr_all = np.round(scipy.stats.spearmanr(a, b)[0], 3)\n",
    "#     print(a, b)\n",
    "#     ax[i].text(low_limit * (7.5/8), up_limit * (3 /4), ''+str('$\\u03C1_{SD}$=') + str(corr[0]), fontsize=12, \n",
    "#                color = color_plate[0], size = 10)\n",
    "#     ax[i].text(low_limit * (7.5/8), up_limit * (2 /4), str('$\\u03C1_{LD}$=') + str(corr[1]), fontsize=12, \n",
    "#               color = color_plate[1], size = 10)\n",
    "    ax[i].text(low_limit * (7.5/8), up_limit * (2 /3), str('$\\u03C1_{All}$=') + str(corr_all), fontsize=12, \n",
    "              size = 10)\n",
    "    ax[i].set_title(title_a)\n",
    "    #     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "0d50b277",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(5849,)"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "degree_labels2.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "12bc189e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 648x216 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_theme(style=\"whitegrid\", font_scale=1)\n",
    "\n",
    "figure, axis = plt.subplots(1, 3, figsize=(9, 3), constrained_layout=False)\n",
    "# figure, axis = plt.subplots(3, 3, figsize=(8, 8))\n",
    "figure.tight_layout(rect=[0.02, 0.03, 1, 0.95], h_pad = 1, w_pad = 2)\n",
    "\n",
    "plot_infl_edge(df0, axis, 0, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.', \n",
    "               low_limit = -0.5, up_limit = 0.5, temp_x_ticks = [-0.5, -0.25, 0, 0.25, 0.5], \n",
    "               title_a=r'$l_{2}$ = 0.1' )\n",
    "plot_infl_edge(df1, axis, 1, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.', \n",
    "               low_limit = -3, up_limit = 3, title_a=r'$l_{2}$ = 0.01')\n",
    "plot_infl_edge(df2, axis, 2, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.', \n",
    "               low_limit = -3, up_limit = 3, title_a=r'$l_{2}$ = 0.003', degree_labels = degree_labels2)\n",
    "figure.savefig('citeseer_theory/citeseer_theory_low_resolution.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "1d576594",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-0.45640952, -0.01953786, -0.03279912, ...,  0.        ,\n",
       "        0.        , -0.0670913 ])"
      ]
     },
     "execution_count": 125,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "450b8017",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>0</th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>degree</th>\n",
       "      <th>degree_labels</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.823030</td>\n",
       "      <td>0.366621</td>\n",
       "      <td>0.0</td>\n",
       "      <td>628.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.016983</td>\n",
       "      <td>-0.002555</td>\n",
       "      <td>1.0</td>\n",
       "      <td>158.0</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.031694</td>\n",
       "      <td>-0.001105</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2919.0</td>\n",
       "      <td>15</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-0.014219</td>\n",
       "      <td>-0.031237</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2933.0</td>\n",
       "      <td>9</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.049353</td>\n",
       "      <td>-0.005146</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1097.0</td>\n",
       "      <td>26</td>\n",
       "      <td>0</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",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12426</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3322.0</td>\n",
       "      <td>3322.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12427</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3323.0</td>\n",
       "      <td>3323.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12428</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3324.0</td>\n",
       "      <td>3324.0</td>\n",
       "      <td>8</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12429</th>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3325.0</td>\n",
       "      <td>3325.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12430</th>\n",
       "      <td>0.281748</td>\n",
       "      <td>0.214657</td>\n",
       "      <td>3326.0</td>\n",
       "      <td>3326.0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>12431 rows × 6 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "              0         1       2       3  degree  degree_labels\n",
       "0      0.823030  0.366621     0.0   628.0       4              0\n",
       "1      0.016983 -0.002555     1.0   158.0      10              0\n",
       "2      0.031694 -0.001105     1.0  2919.0      15              0\n",
       "3     -0.014219 -0.031237     1.0  2933.0       9              0\n",
       "4      0.049353 -0.005146     1.0  1097.0      26              0\n",
       "...         ...       ...     ...     ...     ...            ...\n",
       "12426  0.000000  0.000000  3322.0  3322.0       4              0\n",
       "12427  0.000000  0.000000  3323.0  3323.0       4              0\n",
       "12428  0.000000  0.000000  3324.0  3324.0       8              0\n",
       "12429  0.000000  0.000000  3325.0  3325.0       4              0\n",
       "12430  0.281748  0.214657  3326.0  3326.0       4              0\n",
       "\n",
       "[12431 rows x 6 columns]"
      ]
     },
     "execution_count": 126,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bf46dce9",
   "metadata": {},
   "outputs": [],
   "source": [
    "degree_list = np.array([np.array(graph.in_degrees(f_l[i])) + np.array(graph.in_degrees(t_l[i])) for i in range(len(f_l))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f5ce1dcf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 4, 10, 15, ...,  4,  4,  4])"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "degree_threshold = 25\n",
    "degree_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "83a4945e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "26.0"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "a5102539",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([317., 638., 635., 631., 488., 454., 419., 348., 311., 198., 175.,\n",
       "        170., 146., 121.,  69.,  85.,  54.,  46.,  58.,  57.,  42.,  27.,\n",
       "         22.,   6.,   4.,  34.,  49.,  17.,   9.,   5.,   8.,   0.,   2.,\n",
       "          1.,   3.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          0.,   0.,   0.,   0.,   0.,   0.,  48.,  39.,  34.,  28.,  14.,\n",
       "         16.,   6.,   6.,   2.,   4.,   0.,   0.,   0.,   2.,   0.,   0.,\n",
       "          0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,   0.,\n",
       "          1.]),\n",
       " array([  4.  ,   5.96,   7.92,   9.88,  11.84,  13.8 ,  15.76,  17.72,\n",
       "         19.68,  21.64,  23.6 ,  25.56,  27.52,  29.48,  31.44,  33.4 ,\n",
       "         35.36,  37.32,  39.28,  41.24,  43.2 ,  45.16,  47.12,  49.08,\n",
       "         51.04,  53.  ,  54.96,  56.92,  58.88,  60.84,  62.8 ,  64.76,\n",
       "         66.72,  68.68,  70.64,  72.6 ,  74.56,  76.52,  78.48,  80.44,\n",
       "         82.4 ,  84.36,  86.32,  88.28,  90.24,  92.2 ,  94.16,  96.12,\n",
       "         98.08, 100.04, 102.  , 103.96, 105.92, 107.88, 109.84, 111.8 ,\n",
       "        113.76, 115.72, 117.68, 119.64, 121.6 , 123.56, 125.52, 127.48,\n",
       "        129.44, 131.4 , 133.36, 135.32, 137.28, 139.24, 141.2 , 143.16,\n",
       "        145.12, 147.08, 149.04, 151.  , 152.96, 154.92, 156.88, 158.84,\n",
       "        160.8 , 162.76, 164.72, 166.68, 168.64, 170.6 , 172.56, 174.52,\n",
       "        176.48, 178.44, 180.4 , 182.36, 184.32, 186.28, 188.24, 190.2 ,\n",
       "        192.16, 194.12, 196.08, 198.04, 200.  ]),\n",
       " <BarContainer object of 100 artists>)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsQAAAHsCAYAAADVQrtFAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAavElEQVR4nO3dbWjd5eH/8U89bSyOxZhqa5zFsrLJmcIEBR+5scp/BUnXwR70R9QHu32wTWQqW+ZNU6uDHZ3ohpYyNgYbRVhxa20U4g/KHkyYc7jBuoCKS72ZMdHE4u3W7vT8H/gzqElOkmp6TnK9Xo/a68qhV79c58ubK9/krGg0Go0AAEChTmn1AgAAoJUEMQAARRPEAAAUTRADAFA0QQwAQNFWtnoBM/n3v/+dQ4cO5ayzzkqlUmn1cgAAWMLq9XpefvnlXHjhhVm9evW0+bYM4kOHDuXKK69s9TIAAFhG9uzZk0suuWTaeFsG8VlnnZXknUWfffbZLV4NAABL2UsvvZQrr7xyqjE/qC2D+N3HJM4+++yce+65LV4NAADLwWyP4vqhOgAAiiaIAQAomiAGAKBoghgAgKIJYgAAiiaIAQAomiAGAKBoghgAgKIJYgAAiiaIAQAomiAGAKBoghgAgKIJYgAAiiaIAQAomiAGAKBoghgAgKIJYgAAiiaIAQAomiAGAKBogniejh6rL2gcAIClYWWrF7BUdKyqZMv1+6eNH7hrawtWAwDAR8UJ8Yfk5BgAYGlzQvwhOTkGAFjanBAvEifHAABLgxPiReLkGABgaXBCDABA0QQxAABFE8QAABRNEAMAUDRBDABA0QQxAABFE8QAABRNEAMAUDRBDABA0QQxAABFE8QAABRNEAMAUDRBDABA0QQxAABFE8QAABRNEAMAULR5BfF//vOfDAwM5Itf/GK2bNmSW265JUkyMjKSbdu2ZfPmzdm2bVsOHz489ZpmcwAA0C7mFcR33nlnTj311AwNDeXAgQO59tprkyQDAwPp6+vL0NBQ+vr6sn379qnXNJsDAIB2MWcQv/nmm9m3b1+uvfbarFixIkly5plnZmJiIsPDw+nt7U2S9Pb2Znh4OJOTk03nAACgnayc6wuef/75dHV15d57781jjz2Wj33sY7n22muzevXqrFu3LpVKJUlSqVSydu3ajI6OptFozDrX3d29uP8jAABYgDlPiP/73//m+eefz2c+85n87ne/yw033JBrrrkmb7311slYHwAALKo5T4jPOeecrFy5curxh89+9rM544wzsnr16oyNjaVer6dSqaRer2d8fDw9PT1pNBqzzgEAQDuZ84S4u7s7l156aR599NEk7/z2iImJiWzYsCHVajWDg4NJksHBwVSr1XR3d2fNmjWzzgEAQDuZ84Q4SW699dbceOONqdVqWblyZe644450dnZmx44d6e/vz65du9LZ2ZlarTb1mmZzAADQLuYVxOvXr89vfvObaeMbN27M3r17Z3xNszkAAGgXPqkOAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaIIYAICiCWIAAIomiAEAKJogBgCgaCvn80WbNm1KR0dHTj311CTJDTfckMsuuywjIyPp7+/PkSNH0tXVlVqtlg0bNiRJ0zkAAGgX8z4h/tnPfpb9+/dn//79ueyyy5IkAwMD6evry9DQUPr6+rJ9+/apr282BwAA7eKEH5mYmJjI8PBwent7kyS9vb0ZHh7O5ORk0zkAAGgn83pkInnnMYlGo5GLL7441113XUZHR7Nu3bpUKpUkSaVSydq1azM6OppGozHrXHd39+L8TwAA4ATM64R4z549efDBB/PAAw+k0Whk586di70uAAA4KeYVxD09PUmSjo6O9PX15YknnkhPT0/GxsZSr9eTJPV6PePj4+np6Wk6BwAA7WTOIH7rrbfy+uuvJ0kajUYefvjhVKvVrFmzJtVqNYODg0mSwcHBVKvVdHd3N50DAIB2MuczxBMTE7nmmmtSr9dz/PjxbNy4MQMDA0mSHTt2pL+/P7t27UpnZ2dqtdrU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NOvWrUulUkmSVCqVrF27NqOjoz4pbwbHjx/P/fffn02bNk2N3XDDDWk0Grn44otz3XXXpbOzs4UrbC8fvDb22/wcPHgw69atywUXXDA1Zp/Nrtm+ajQa9twcZrqvJfbcbGa6Lu5tc5vpvpbYZ8n734NL4X62LE+IWZjbbrstp512Wq666qokyZ49e/Lggw/mgQceSKPRyM6dO1u8wvbh2py4Bx544H2nKK4li+mD97XEnpuN63LiPnhfS1zPd830HmxnyzKIe3p6MjY2lnq9niSp1+sZHx9f0LeKSlGr1fLss8/mnnvuySmnvLMd3r1OHR0d6evryxNPPNHKJbaVma6N/Ta3sbGxPP7449myZcvUmH3WXLN9Zc81N9N9LbHnZjPbdbHPmpvpvpbYZ8n09+BSuJ8tyyBes2ZNqtVqBgcHkySDg4OpVqu+xfMBd999dw4dOpT77rsvHR0dSZK33norr7/+epKk0Wjk4YcfTrVabeUy28Zs18Z+m9vvf//7fP7zn88ZZ5yRxD6bj2b7yp6b3Uz3tcSem02z62KfNffB+1pinyUzvweXwv1sRaPRaJzUf/EkeeaZZ9Lf35/XXnstnZ2dqdVq+eQnP9nqZbWNp59+Or29vdmwYUNWr16dJDn33HPT39+fa665JvV6PcePH8/GjRtz8803Z+3atS1eces9//zzs14b+625zZs356abbsrnPve5JM2vZYluv/32PPLII3nllVdyxhlnpKurKw899FDTfVX6npvpmt1zzz0z3tfuu+8+ey4zX7Pdu3c3vS722czvzWT6fS1xb5utLe677762v58t2yAGAID5WJaPTAAAwHwJYgAAiiaIAQAomiAGAKBoghgAgKIJYgAAiiaIAQAomiAGAKBo/x8H5hfd8F1+RAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axs = plt.subplots(1, 1,\n",
    "                        figsize =(10, 7),\n",
    "                        tight_layout = True)\n",
    " \n",
    "axs.hist(degree_list, bins = 100)"
   ]
  }
 ],
 "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
}
