{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import dgl\n",
    "from dgl.nn import ChebConv\n",
    "import networkx as nx\n",
    "import networkx.algorithms.community as nx_comm\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import numpy.linalg as alg\n",
    "from scipy.spatial.distance import mahalanobis as mah_dist # u, v, cov_mat\n",
    "import os\n",
    "from tqdm.notebook import tqdm\n",
    "from functools import reduce\n",
    "import argparse\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def node_connects_cluster(node):\n",
    "    return set(map(lambda x: inverse_cluster_dict[x], list(g[node]))).union(set([inverse_cluster_dict[node]]))\n",
    "\n",
    "\n",
    "path = 'Dataset/socfb-Stanford3.mtx'\n",
    "\n",
    "df = pd.read_table(path, skiprows=1, names = [\"source\", \"target\"], sep=\" \")\n",
    "g = nx.from_pandas_edgelist(df)\n",
    "\n",
    "# calculate basic elements\n",
    "num_nodes = g.number_of_nodes()\n",
    "num_edges = g.number_of_edges()\n",
    "degs = [g.degree[i] for i in g.nodes]\n",
    "avg_deg = sum(degs)/len(degs)\n",
    "\n",
    "res = 5\n",
    "\n",
    "# clustering\n",
    "# generally, we fix the outcome of clustering\n",
    "clusters = nx_comm.louvain_communities(g, seed = 10, resolution=res)\n",
    "clusters = sorted(clusters, key = len, reverse=True)\n",
    "cluster_sizes = list(map(len, clusters))\n",
    "num_cluster = len(clusters)\n",
    "\n",
    "# dict: from node to its cluster\n",
    "inverse_cluster_dict = {\n",
    "    node: cl for cl in range(num_cluster) for node in clusters[cl]\n",
    "}\n",
    "\n",
    "# dict: from node to its connected cluster\n",
    "node_to_connected_clusters = {\n",
    "    node: node_connects_cluster(node) for node in range(1, num_nodes + 1)\n",
    "}\n",
    "\n",
    "for i in g.nodes:\n",
    "    g.nodes[i][\"n_cl\"] = len(node_to_connected_clusters[i])\n",
    "    g.nodes[i][\"deg\"] = g.degree[i]\n",
    "\n",
    "rev_cluster_sizes = cluster_sizes[::-1]\n",
    "rev_clusters = clusters[::-1]\n",
    "rev_cluster_sizes = np.array(rev_cluster_sizes)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "568309"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "node_list = list(g.nodes.keys())\n",
    "node_list = np.array(node_list)\n",
    "\n",
    "# from node to index in node_list\n",
    "node_list_index_dict = {}\n",
    "for node in g.nodes:\n",
    "    node_list_index_dict[node] = np.where(node_list == node)[0][0]\n",
    "    \n",
    "\n",
    "# from graph index to feature vector index\n",
    "dict_from_graph_to_feat = {}\n",
    "for i, node in enumerate(g.nodes):\n",
    "    dict_from_graph_to_feat[node] = i     \n",
    "    \n",
    "    \n",
    "# compute interior nodes    \n",
    "interior_nodes = []\n",
    "for i in g.nodes:\n",
    "    interior_flag = 1\n",
    "    cluster_index = inverse_cluster_dict[i]\n",
    "    for nb in g[i]:\n",
    "        if inverse_cluster_dict[nb] != cluster_index:\n",
    "            interior_flag = 0\n",
    "            break       \n",
    "    if interior_flag == 1:\n",
    "        interior_nodes.append(i)\n",
    "    \n",
    "boundary_nodes = np.array(list(set(node_list).difference(set(interior_nodes))))\n",
    "\n",
    "boundary_nodes_feat_index = [dict_from_graph_to_feat[node] for node in boundary_nodes]\n",
    "interior_nodes_feat_index = [dict_from_graph_to_feat[node] for node in interior_nodes]    \n",
    "\n",
    "\n",
    "np.random.seed(0)\n",
    "x_coef = np.arange(1, 6)\n",
    "x_vec = np.random.normal(0.1, 0.1, size=(num_nodes, len(x_coef)))  \n",
    "for i in range(num_nodes):\n",
    "    g.nodes[node_list[i]][\"x\"] = x_vec[i]\n",
    "\n",
    "\n",
    "normalized_deg_array = np.array(degs)/avg_deg\n",
    "is_inner_node_array = np.zeros(num_nodes)\n",
    "number_of_connected_clusters_array = np.zeros(num_nodes)\n",
    "for node in g.nodes:\n",
    "    if node in interior_nodes:\n",
    "        is_inner_node_array[node_list_index_dict[node]] = 1\n",
    "    number_of_connected_clusters_array[node_list_index_dict[node]] = g.nodes[node][\"n_cl\"]\n",
    "\n",
    "normalized_number_of_connected_clusters_array = number_of_connected_clusters_array / number_of_connected_clusters_array.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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GJoz530tXvy5Gja8wiWU8QUEBgAAAABQhi70HfqkpEStXLnc+Xm7dh2cKyJERETmeU5+3rw5Bdbz66+/SJIGDhzistpAZGQl5+v8RiqsXLlcv/++XZJclnZ0uJB5Eez2vKFD7943OScHPHHiuCZPfiPfco6VFCTpzJkzztcpKUnO17t2/e5SLiUlRenp51zamZHxz6gLx/flQudQaNq0mZo1u0aStHr1t1qxItanllLMjcAAAAAAAMqQY3m/okhISNBTTz2q1NScm+Pq1WvoiSeezXPMiBEPql69SyVJX331hdavX+dSz7ZtWxQX95MaNrxCd9wxzGX/1Vc3c76eOXOqVq5cpqNHj2jjxg169tkntHr1t2rQoKEk6dy5c1q27Gvt3fuHTp1KkSRlZWU5X6em5h8o5J6nIDk5Jc++qlWradiwEc7Pv/hiocaNe04nThyXlHOTv2zZ13r33enOY5YuXaJt27Zq27atqlmztnMpxF9+2ajp06coOTlJf/11TB9/PFsjRtypjIycUQuHDx9SQkKCpk+foh07tjvrO3fu3N/7D+dpa1Hceecw5zUGBgbq+uu7XVB5b0FgAAAAAABlxDAMrVmzyvl5auoZLVr0mX77bbMOHTqopKREHT16RPHxcZo69R0NGdJfO3fukCQ1b95C77wzXZdcUjlPncHBwXr77Wlq1OhKGYah0aOf1IcfztKBA/v111/H9MUXC/XEE//Rtddep3femS6r1erSrubNWzgnVkxJSdb48WM1YEA/PfLIAwoLC9NLL02UxfJPuSlT3lJs7Ney2Wz6669j+uCDd5WVlSVJ+vPPPVq06DMdP/6XbDab0tPTdfjwIX300QfO8r/+ukmrVn2rpKRE57Y77him228f4vz8229X6NZb++qWW/qod+/r9fnnCzR48B3O/b/8slELFy6Qn5+fQkNDFRPT37lv3rw56tu3m269ta/Wrfteb789TZdfXt95fdHRPWQymXTVVU11+PAhvffeDGeQk5ycpNdfn6C9e//MMwKhMK1atXE+CtGnT7QCAgKKVM7bmIySmKECRWaz2ZWUdLasm3FeAQFWhYcH6diXU5WZcNStOvwrVVe1fg8qOfmssrMvLKEDLoTValZERAh9DT6DPgtfQn/1TllZmUpMPKZKlarJz6/oS8U5vp/zl/+uE0mFP6fuy0wmU6HD/qMi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zzymMWNe1F13DVf9+g1UtWpVde16g6ZPf1+RkZWUmZmhl156Xn/++YckqUqVqnr44cfUoEEjZz1btvyqDRviNGPGB2rfvqPznFFRUbrxxh6aMmWmKlX65wY/P2lpZ/XII/dr27YtevnlSRo0aKhq1qylmjVraeDAIXrzzSmyWq3avn2rHnroPp09m+osW6/epXriiWfyrECxcuUynT2bqqlTZ+mqq5pKkqpXr6mAgMCif0MuMgQGAAAAAOClqlSpKn9/f7Vqda1z26+/btbLL0/SgAGDVLFiRVmtVnXq1FVdutwgKedGe9eu39063//934tq2rS584Y6t/DwCrr66maSJJvNpk8/nS9JatLkKl1xRWP16NHLeezKlcv0f//3mpo0uVoTJ76pjz5aoHnzPld4eAXVrVtPNWrUVMOGVxbalnffnab9+/epWbNrdN117Vz2N2lytQYOHCpJOnBgv6ZMecu5r1mza3TVVU3VqVNX57b4+J/13HPj1LRpc02b9p4+/HCePvjgY5dVKvAPvjIAAAAA4OWCgoKdr2+8sbuqV6/hckzDho20YkWspJw5Dy7U5s2btGfPbh04sF89enTO95jcIxd27swbSuRu491336vg4BDn55deeplLXSEhIS7bHBITE7RkySJJ0rXXti3wuP79b9cnn3ys7OxsLVv2te6++15VqVI1V5v+GT0xcuQoZzhgMplUv37DAutFDgIDAAAAAPByZvP5B4fnfg4/9419UW3cuEGS1KvXTRo8+I7zHv/vd+YtFovzdaVKl5y3fO7j/2316m+VlZUlSapatWqBx0VGVlKTJlfr119/kc1m0/r16xQdfavbbUJeBAYAAAAA4OUKWgWgoGMMw7jgcxw4sP/vsvYCVyzwpMKuadu2rc7X55uQsEGDhvr1118kSQcOHPBM4yCJOQwAAAAAAJJSU89Iknbv3lXGLZFSUpKdr8+dSyv02IiIfyZPzL2SBIqPwAAAAAAAoMDAnNUCdu/eqePH/zrv8UeOHC6xtuSe/+DYsaPnOfafuRMKe3wBF47AAAAAAACgqlVzHkOw2WyaPfu9Qo9NTk7WO++8XmJtueyyy52vd+zYXuixGRn/zNfQuPFVJdamixGBAQAAAABALVq0dL7+6qsv9NVXXxR47OTJb6h585YF7i+ujh27OF/Hx8cpLe1sgcceO3ZMklS9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STh69Gih+w3DUFZWlv744w998803OnTokGrVquWJUwMAAAAAgBLgkcCga9euF7Tywdy5c/Xss8964tQAAAAAAKAEeOyRBMMwivyxaNEiT50WAAAAAACUAI+MMJCkxx57TN26dZOfn1+++48cOaJp06Zp3LhxBR4DAAAAAAC8g0cCA4vFohEjRhR6TI0aNbR//369+uqrmjZtmidOCwAAAAAASohHHklYvXp1kY6LiYnRhg0bNGvWLE+cFgAAAAAAlBCPBAZRUVFFOs5qtSo4OFiffvqpJ04LAAAAAABKiMfmMCiKlStX6uTJkwoKCirN0wIAAAAAgAvkkcDgjjvuKHS/YRg6efKkDhw4IJPJpGuuucYTpwUAAAAAACXEI4HBhg0bZDKZZBjGeY+tVauWxo0b54nTAgAAAACAEuKxRxLq16+vLl265LtkosViUUhIiC699FK1adNGVmupPgkBAAAAAAAukEfu3E0mk2bPnq3IyEhPVAcAAAAAAMqYR1ZJGDJkCGEBAAAAAADliEdGGDz33HN5Pj927Jh+//13ZWZmqlq1arriiivk7+/viVMBAAAAAIBS4NHJBHbu3KlXXnlFGzduzLM9LCxMvXv31sMPP6yIiAhPnhIAAAAAAJQAjzySIEnffPON+vfvr40bN8owjDwfp0+f1ieffKLevXtry5YtnjolAAAAAAAoIR4ZYXDgwAE98cQTysrKUr169dS7d29dddVVqlKligICAnT27Fn9+eef+vLLL/XAAw9oyZIlqlSpkidODbjNYil+Xma3G7Lbz7+cKAAAAAD4Go8EBrNmzZJhGBo/frwGDBiQ7zFNmjRRv3799Oqrr+rjjz/WI4884olTAxcsLNhPdruh8PCgYtdls9uVkpxGaAAAAACg3PFIYPDTTz/phRde0C233HLeY0eNGqWBAwcSGKDMBAZYZTab9MmKnTqeeNbteqIigzWoxxUym00EBgAAAADKHY8EBikpKerXr1+Rjg0ODtbx48c9cVqgWE4kpenIydSybgYAAAAAeCWPTHpYqVIlGUbR3mFdvXq1TCaTJ04LAAAAAABKiEcCg+bNm+vTTz8973EbN27Uc889p6uuusoTpwUAAAAAACXEI48k3HnnnRo8eLCOHz+u6OhoXXrppc59SUlJ2rRpk7744gutXr1ahmHojjvu8MRpAQAAAABACfFI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IrUdAABfRmAAAAA8btWqVdq9e7ckqX379s4JC+vVqydJ+uCDDwosu3nzZi1cuDDPtiFDhqhx48YKDAxU//791aVLF3333XcaN26c3nnnHZnNF/4njaMtK1ascM5T8G92u13PP/98nuOPHj2q5cuXF1jvyy+/nGeVBwAAfBWBAQAA8KiEhATnTXZ4eLheeukl574uXbpIyplwcObMmS5l09PT9eqrr6p9+/bObampqRo6dKgGDhyoWbNmaf369fr555+1YMECDRw40K2wQJI6deoki8WijIwMPfLII85HFHKbPXu2atasKUm6/PLLVbt2bUnSiy++6AxEctu8ebOOHDniHL0AAIAvY9JDAABQJEWZd+DgwYO69957dfLkSUVGRmr69OnOCQ8lafDgwfrkk0908uRJvfnmm/r111912223qUqVKtq3b5/ee+89NW3aNE+ZWbNmaffu3Tp48KC2bdumoKAgmUwmWSwW+fn5KTw8XKGhoS5tyc7OliSlpKTk29aaNWvqlltu0aeffqotW7aoX79+GjFihK6++mqdOXNGsbGxWrVqlWJjY51lHn74YT3xxBNKSUnRbbfdprvvvlsdO3aUyWRSXFycPvjgg3yDEAAAfJHJYKFgAABwHseOHVOXLl1kGIYaNGigSZMm6bLLLpO/v78yMzO1Z88eff3115o3b54yMzN1/fXX65lnnnEue5jbr7/+qhEjRujUqVMu+6655hp9+OGHed6hnzhxoj788MNC29e4cWM9++yzzskVjxw5ottvv10nTpxQcHCwZsyYoWuvvdal3Llz53T//fdr/fr1LvuCg4P1/vvv65prrsmz/c033ywwFHjuued0xx13FNpWAAB8BYEBAAAo0IYNG7R69WotX75cR48eddkfHBwsi8WiChUqqFatWmrdurWuv/56NWzYsNB6jx07pqlTp+r7779XcnKyqlWrpptuukn33nuvy3D+rKwsPfjggzpw4IAyMjJ0+vRpZWRkOEcQOAQGBurrr7/W3LlzNXv2bJdzNm/eXP/73/9ctmdnZ2v+/PlauHCh9u7dq+DgYF177bX6z3/+o8suuyzf9q9Zs0YffPCBtm3bJrvdrsaNG2vEiBHq1KlTodcNAIAvITAAAABeLT4+XtOmTdOsWbNkteZ9mtJut+vs2bP6448/9Mwzz2jIkCEaOnRoGbUUAIDyhTkMAACA1/rrr780atQozZgxwyUskCSz2aywsDA1b95cXbp0cXsCRAAA4Ir/VQEAgNd6/fXXlZKSIn9//0KPO336tFavXu1chQEAABQfgQEAAPBae/fulSSNHDlSn3/+ucuKB5mZmfr+++81cOBADRkyJM/qCgAAoHiYwwAAAHitzZs366GHHtLJkyed2ypVqqTQ0FBlZWXp5MmT8vPz0/PPP6+bb765DFsKAED5Q2AAAAC8Wmpqqj799FN999132rNnj86ePavQ0FDVqVNHHTp00KBBg1SpUqWybiYAAOUOgQEAAAAAAHDBHAYAAAAAAMAFgQEAAAAAAHBBYAAAAAAAAFwQGAAAAAAAABcEBgAAAAAAwAWBAQAAAAAAcEFgAAAAAAAAXBAYAAAAAAAAF/8PiJdHsC3ExKEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "deg_array = np.array(degs)\n",
    "plt.figure(figsize=(12, 6))\n",
    "\n",
    "int_deg = deg_array[interior_nodes_feat_index]\n",
    "bnd_deg = deg_array[boundary_nodes_feat_index]\n",
    "\n",
    "tick_fontsize = 20\n",
    "\n",
    "\n",
    "sns.histplot(bnd_deg[bnd_deg<=100], label = \"Boundary\", bins=np.arange(0, 100, 2))\n",
    "sns.histplot(int_deg, label = \"Interior\", bins=np.arange(0, 100, 2))\n",
    "plt.legend(prop={'family': 'Times New Roman', 'size': 24}       )\n",
    "\n",
    "plt.xlabel(\"Degree\", fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.xticks(fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.ylabel(\"Count\", fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.yticks(fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "\n",
    "\n",
    "plt.savefig(\"Figures/deg_dist.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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14QJEyTx/z9wH4FBBfK3v/1N0h8rov5Zenq6M53v2LFjibULKE4zZsxQZmamYmNj8y3TunVrSfm/NhxvtCSpU6dOnm0g4CE2m012u13p6el5fhmGISlnHmp6erouXbokif6P8sPx5ufUqVP5lqlVq5akP0Zd0v9RXiQkJGjXrl0KDQ01LWJYtWpVTZ8+XT4+Pjp48KCOHj0qif4P9xAYVCC9evWSlDPH78yZM6bzP/30k6ScxLF9+/Yl2jagOCxfvlw7duzQtGnTChyi7XhtJCYmym63m84nJiZKyvkfzWbNmhVPY4GrNHnyZCUmJub7df3110uSJk2apMTERK1fv14S/R/lR1hYmKScqQmON0R/lpqaKklq0aKFJPo/yg9Hn/f29s7zfIMGDdSuXTtJf4wopv/DHQQGFcgNN9ygLl26SJJppVRJzr2JIyIiVLVq1RJtG+Bpn3zyiVasWKFZs2Y5twTKzWazae3atZKkLl26qEmTJkpPT1d8fLyprOO1MXDgwOJtNFAK6P8oL9q2basbb7xRkrR69eo8yxw6dEgWi0X33nuvJPo/yo969epJygkO8nrzL+XsIGK1WtWgQQNJ9H+4h8Cgghk1apR8fX310UcfuRy/dOmS/vOf/6h69ep6+umnS6dxgIesWrVKCxYs0GuvvaasrCwlJyc7v3777Td99913Gjp0qHOLIIvFopdfflkWi0XLly93udbZs2cVFxen0NBQPfzww6XxOECxov+jvLBarRo9erS8vLy0dOlS02jKH374QTt37tT999/vDBbo/ygvWrZsqZtvvlkXL17Uhx9+aDqflJSk//3vf7rjjjsUHBwsif4P9xAYVDCNGjXSpEmTtHfvXr3++uvKysrS6dOn9fTTTystLU1z5szRddddV9rNBK7YsmXL9K9//UuHDx9Wr1691KFDB5evbt26aciQIdq1a5d69uzprNeuXTuNHDlSa9as0ZIlS2S323X06FHFxMSoWrVqmjt3boH7FANlGf0f5cVtt92mcePG6dy5c4qJidHPP/8sSdq5c6eeffZZdevWTaNHj3apQ/9HeWCxWPTmm2+qbt26ev311/Wf//xHWVlZstls+vHHHzVs2DA1bNhQ48ePd6lH/0dhLIZjFSRUKDt37tSMGTO0f/9++fv7q1u3bnrsscdUs2bN0m4acMW++uorPfHEE26VDQ8P12uvvWY6vn79es2bN0+HDx9WUFCQevfuraFDhzpX3wbKqh49eujXX3/VpEmTXFbQzo3+j/Li+++/19y5c7Vnzx5VrlxZDRo0UN++fdWvXz9ZLJY869D/UR6cO3dOCxcu1Ndff61Tp07J29tbISEhuuuuuxQVFZXnNE2J/o/8ERgAAAAAAAATpiQAAAAAAAATAgMAAAAAAGBCYAAAAAAAAEwIDAAAAAAAgAmBAQAAAAAAMCEwAAAAAAAAJgQGAAAAAADAhMAAAAAAAACYEBgAAAAAAAATAgMAAAAAAGBCYAAAAAAAAEwIDAAAQIWQmZmpjz/+WH369NGMGTNKpQ0HDx5UbGysWrdurRMnTpRKGwAAcJd3aTcAAIDS9sILLyg0NFRPPPGEy/Hu3btr8uTJuu222/Ktu3v3bq1atUrx8fE6ceKEKlWqpKCgIDVv3lx9+vRRly5ddPr0ab399tuaMmVKcT8K8rF06VItWLBAv//+uyTp9ttvv+JrZWVlKS4uTuvWrVNCQoKSk5NVvXp1XXfdderUqZPCw8N1ww03aP78+WrWrJm6dOmi9PR0jRkzRhs2bFB6erqnHgsAgGJFYAAAqPD27t2rPn36uBw7c+aMfv/9d/31r3/Ns87vv/+u8ePHa8OGDerYsaOef/55tWjRQtWrV1dGRoZ27typd999Vy+//LLsdrtuuummkngU5OPee+9VRESEunXrprS0tCu+zvr16xUbG6vz58+rb9++GjFihBo1aqRKlSrp9OnT+uqrrzRkyBAFBgbqyJEjzpCoSpUqmjZtmr799lsNGzbMU48FAECxYkoCAKBCu3Dhgo4ePWoKBn788UfdcMMN8vf3N9VJSEhQZGSkNmzYoLFjx+q9995T165dVb16dUmSr6+vOnXqpHfeeUcPPPCAkpOTdf78+ZJ4nDLrzTffLNYh+n5+fqpataoaNGhwxdeYPXu2HnvsMWVnZ2vFihUaPXq0brzxRlWqVEmSVKtWLQ0cOFCff/65/P39ZbPZTL/3kJCQq3oOT3nuuedKuwkAgDKAwAAAUKHt3btXdevWVXBwsMvxH3/8Ubfeequp/O+//65hw4bp7NmzGjx4sKKiogq8/rBhw3TPPfcQGBQgNTVVH3zwQYncy9fX94rqffTRR3r77bfl5eWlmTNn6i9/+Uu+ZatVq6bZs2crODjY9Hv38fG5ovt70rFjx/Tll1+WdjMAAGUAgQEAoELbu3evbrnlFtPxXbt2qUWLFqbj48ePV1JSkvz9/fXkk0+6dY/nnntOmZmZV93W8uqVV14psUDFy8uryHVOnjypSZMmSZLuvPPOPIOkP6tRo4ZiYmKUmprqctxisRT5/p5ks9n00ksv6fLly6XaDgBA2UBgAACo0Pbs2WOajmC325WQkGB6Y7hr1y5t2LBBktSlSxdVq1bNrXvUrFlTHTp0kGEYnml0OWG32zVhwgR98cUXpd2UAs2dO9e5UOFdd93ldr17771XWVlZxdWsIrt06ZKeffZZ7dixo7SbAgAoI1j0EABQocyfP1/z5893/j0tLU2bN2/WvHnznMfsdrsyMjKc0w3GjRunPn366OOPP3aW6dy5c5Hu+9xzz8kwDNMnzFu3btXSpUu1b98+JScnq1atWuratauGDRummjVrmq6zdetWLVq0SOnp6VqyZIlOnz6tN998U+vXr5fVatU999yj559/XlbrH58JZGdna/369Vq0aJFCQkI0adIkHT16VNOmTdN3330nf39/Pfjgg3rkkUfybHtKSooWLFigDRs26OTJk6pcubLatWunJ554Qs2aNcuzzldffaVly5bpwIEDysjIUGhoqPr376++ffvK29tb6enpiomJ0d69e5117r77bme7v//+e+faAIZh6PPPP9dHH32kn3/+Wenp6WrcuLEGDBigfv365Xn/U6dOac6cOdq4caNSUlJUo0aNQqeP5CUrK0uff/65JKlSpUpq166d23WrVq2q6OjoQsvt2bNH999/v2w2m/PY119/rfr160uSHn30UW3cuNF5bvjw4abRLevWrdOcOXN05MgRl10YHnjgAY0ePVqnTp3SY489piNHjjjPtWnTRlLOaIjcUxRsNpuWL1+uVatW6dixY8rKylLz5s318MMP6x//+IfLfXfv3q0PPvhAcXFx2rVrl3bt2qVx48bpxIkTeuGFF3TfffdJkuLj4/X2229r//79unjxojM8+/vf/67Zs2cX+jMCAJQSAwCACuqXX34xmjdvbmRkZLgcX7VqlXHfffeZynfv3t1o2rSp0bRpU2P//v1Xff833njDaNWqlfHFF18YNpvNuHjxojFv3jzjxhtvNNq0aWPs3LnTWXbr1q3GkCFDnPePiooyEhMTjc6dOxsdO3Y0WrVq5Tw3a9YsZ70vv/zSuO+++5znXnzxRWPLli1G69atjbCwMOOWW25xnlu1apWpjT/99JPxj3/8w/jggw+M9PR0Iz093dnGW265xdi0aZNL+cuXLxsjR440OnXqZGzcuNHIysoyzpw5Y0RGRhpNmzY1oqOjDbvd7ix//Phx5/2PHz9uun9WVpbx5JNPGiNGjDBOnjxpGIZhbN++3ejWrZvRtGlT46WXXjLV2bVrl9GmTRtjwIABxrFjxwzDMIzvv//e6NSpk9GsWTOjadOmxvTp0936HW3bts3ZvvDwcLfqFCS/5718+bIxbdq0fH8Whw4dMlq2bJln21evXm20bNnS+Oabb4zs7GwjLS3NeO+994ybb77ZmDBhgkvZrVu3Ou+Rl7S0NGPQoEFGbGyscfbsWcNutxvr1q0z2rZtazRt2tSYOXOmYRiGcfjwYWPIkCHGjTfe6LzeoUOHjC5dujiPde3a1TAMw4iPjzduueUWY8WKFYbNZjMuXbpkrFy50mjVqpXx2GOPXe2PFABQjJiSAACosA4cOKBGjRqpcuXKLsf37dun5s2buxxLT0/Xr7/+6vx7UFDQVd37448/1rx58/T888/rzjvvlJeXl6pUqaJhw4bp0UcfVWpqqqKjo/X7779Lklq0aKF33nlHPXv2lCQlJSVp6tSpmj59ur777jtt375d3bt3lyQtW7bMeZ8uXbroww8/dG7reOjQIS1evFgffvihNm7cqK1btzqnZOSu53jmxx9/XA8++KDuv/9++fn5yc/PT8OGDVN4eLgyMzP14osvKiMjw1nnjTfe0KpVqzRz5kyFhYXJx8dH1113nXMkwIYNG/Tdd9+5/XN6++23derUKU2bNk1169aVJLVt29a5psCKFSv03//+11k+KSlJw4YNk5+fn+bNm+fclaBDhw6aMmWKsrOz3b63JB08eND5/dX+zgvi7e2te+65J9/zjRs31o033pjnuRkzZqhz587q2rWrLBaLqlatqoceekgxMTFFbsfYsWMVHBzs/NNqtapnz5568cUXnfdKSEhQo0aN9M477ziPS9KcOXO0cuVKvf/+++rYsaMefvhhSTlTOm644QZFRkbKy8tLvr6+ioiI0NixY4vcPgBAySIwAABUWAcOHMhzSH1egUFaWprL36/mzWN6erqmTJkib29v3X333abzjz/+uAICApSamqo3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543iY489pm+++Ub79+9XXFycBg4cqObNm6tevXqSpFtvvdX5xjohIUH333+/1q5d6yzfr18/ZWdnuyzGl/tNsmMxyHfffVf79+9X/fr1de+990qSdu/erfDwcH344Yfat2+ftm3bpnHjxum9995zbidZo0YN3X///ZJytlrMa2qE4832n7cgLMy0adPUsmVL2e12Pfroo4VOu1izZo1+/PFH06Kaly5dcn7/50AlICDA+fNevHix8/zevXv1+OOPO393hw4dkvTHFIyLFy9qypQppjY4fi+5tw7N/fPevn27DMPQlClTlJSUpDZt2qhTp06SpA0bNujee+/Vp59+qv3792vz5s166qmnFB8frzvuuMN5jdzBS37rJRiGoVdeecV03DEiJK+tTQEA1wYCAwBAhXPixAlduHBBzZs3dzm+Z88e/fWvfy105fdHHnlEb7zxhoKDgzVr1iz1799fn332mU6dOqXs7GzZbDYdPXpUM2fO1OTJk/XKK6+YphU89dRTuuuuu5SRkaGhQ4dqx44dMgxDycnJGjlypLKysjRnzhyXrRvT0tL0/fffS8pZ0d4xCsEh99DztWvXOoeunzp1yrkOwf/+9z+XRQSzs7P11VdfudRzqF69umbOnKlq1apJktavX6/o6GhFRETomWeeUeXKlfXiiy+6tGHSpEnON4D79+/XU0895Sx/+fJlvfbaay7lq1WrptDQUEnSK6+8orCwMP3444/O382oUaOcc95//fVXjRs3Tvfcc48eeOABffbZZ3r77bcVEBDgvN4LL7yg2267TXa7XdHR0c6tHlNTUzVlyhQdOHBAUs4b4q+//jrfqRN/5u/vr3feeUf333+/kpOTNXjwYL300kv63//+5xz5cPHiRW3dulUjR47U8ePHNWrUKNN1cv98P/vsM9N0hb59+zrLdejQQV26dNGjjz6q559/3rlt5vr163Xfffe57F7x4YcfauLEic71IeLj47Vq1Sr17NnTZYeJxo0bO3fneOyxx5yjQxxTbaZOner8/f30008aOXKkIiIi9Mgjj2jnzp16++23ncFXVlaWPv/8c+e1586dm28gtXHjRj333HM6efKkpJwdSpYsWaJbb73VGQoBAK49FqOgSXIAAJRDa9as0cKFC03z0SdMmKAqVaro2Wefdes6qampiouL07p163TkyBElJSXJx8dHNWvW1K233qq7777b+YYsP5999pmWL1+uxMREeXt7q27duurdu7cGDBjg8kZ41apV+te//mWav96uXTtNnTpV//jHP0yjCipVqqTo6GjNmDHD5bjFYlFERITuv/9+RUVFmYa4X3/99Vq/fr3z77/99ptmzZqlb7/9VufOnVPdunV1991369FHH3UulJdbenq6FixYoC+++EK//fabateurbvuukvR0dF5brm4Z88ejRo1SidPnlTv3r310ksvuXwSbrPZtGzZMq1YsUKHDx9WlSpVdNttt+mpp57Kc/u/rKwsLV68WCtWrNCJEycUFBSkVq1a6cEHH9Rbb72ls2fPqmPHjurQoYNuu+22Are3zEtiYqK++OILfffddzp16pRSUlIUFBSkOnXqqFOnTrrvvvucn+7ndtttt5k+hffx8dGaNWsUEhIiKecT+zfffFMrVqxQVlaWOnfurJEjR+r666/XAw88IG9vb0VFRalbt27O6QVt2rRxma4RGBio+vXr6/7771ffvn3l5eXlcs9vv/1Wr776qtLS0tS3b189++yzLmUuXbqkd955R1988YVOnDihatWqqUuXLnrqqaecC3Du27dPffv2NU3t8Pb21meffebyewkPD3cGNVLO1B5HH3rwwQddFvgEAFxbCAwAAAAAAIAJUxIAAAAAAIAJgQEAAAAAADAhMAAAAAAAACYEBgAAAAAAwITAAAAAAAAAmBAYAAAAAAAAEwIDAAAAAABgQmAAAAAAAABMCAwAAAAAAIAJgQEAAAAAADAhMAAAAAAAACYEBgAAAAAAwITAAAAAAAAAmBAYAAAAAAAAk/8HErFr7F/p1T4AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1200x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(12, 6))\n",
    "sns.histplot(number_of_connected_clusters_array, binwidth=1)\n",
    "\n",
    "\n",
    "plt.xlabel(\"#Connected Clusters\", fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.xticks(fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.ylabel(\"Count\", fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "plt.yticks(fontsize=tick_fontsize, fontname=\"Times New Roman\")\n",
    "\n",
    "\n",
    "plt.savefig(\"Figures/hist_ncl.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "int_1hop_int_prop_list = []\n",
    "bnd_1hop_int_prop_list = []\n",
    "\n",
    "for i in interior_nodes:\n",
    "    int_ngbr = [j in interior_nodes for j in g.neighbors(i)]\n",
    "    int_1hop_int_prop_list.append(sum(int_ngbr) / len(int_ngbr))\n",
    "    \n",
    "for i in boundary_nodes:    \n",
    "    bnd_ngbr = [j in interior_nodes for j in g.neighbors(i)]\n",
    "    bnd_1hop_int_prop_list.append(sum(bnd_ngbr) / len(bnd_ngbr))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot:ylabel='Proportion'>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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sOPz+VRYWKisrCylp6dr7ty5On369BXnf/rpp7rnnnuUmZmpiRMnavHixfrqq69srBgAAHQlEQ87RUVF2rlzp/Ly8rRr1y45HA7l5OSooaHBb25FRYXmzJmjXr16afv27frNb36jiooKzZ8/X/X19RGoHgAAdHYRDTsNDQ3aunWrFi1apMmTJys1NVUFBQU6d+6cDhw44Df/zTffVG1trX7xi1/oBz/4gX70ox8pPz9f//u//6sPPvggAs8AAAB0dtGR3PjJkydVXV2tCRMmNI+53W6lpaXpyJEjuuWWW1rMnzhxon79618rJibG77EqKys7VEt0dOhzn9P57cd02L797qKpzy37jVCjz/agz/agz/bpDL2OaNgpLS2VJKWkpLQYHzBggEpKSvzmDxkyREOGDGkx9vzzzysmJkbjxo0Luo6oKIcSE3sFff+2+Brq5Wg750hS2LbfnbjdcZEuoVugz/agz/agz/aJZK8jGnZqa2slSS6Xq8V4TExMQHtqXnzxRe3YsUOPPPKI+vbtG3QdPp8lj6cm6PtfidMZpfjYKFnW1edWVFSHfPvdhdMZJbc7Th5PrbxeX6TLMRZ9tgd9tgd9tk+4eu12xwW8tyiiYSc2NlbS5bU7TT9LUn19veLirpwALcvSr371K23atEkLFizQ3Xff3eFaGhvD9WZveiHaTjzh23734fX66KMN6LM96LM96LN9ItnriB6sbDp8VVZW1mK8rKxMycnJrd7n0qVLys3NVXFxsVasWKFly5aFvU4AANB1RTTspKamKj4+XocPH24e83g8OnHihDIyMlq9z4oVK/TnP/9ZzzzzjObNm2dXqQAAoIuK6GEsl8ul7OxsrV+/XklJSRo8eLDy8/OVnJysadOmyev1qry8XL1791ZsbKxefvll7du3TytWrND48eN1/vz55sdqmgMAAPBtET/nbvHixZo5c6ZWrlypWbNmyel0asuWLXK5XCopKdGkSZO0b98+SdLrr78uSXr66ac1adKkFn+a5gAAAHxbRPfsSJLT6VRubq5yc3P9bhsyZIg++eST5t+3bt1qZ2kAAMAAEd+zAwAAEE6EHQAAYDTCDgAAMBphBwAAGI2wAwAAjEbYAQAARiPsAAAAoxF2AACA0Qg7AADAaIQdAABgNMIOAAAwGmEHAAAYjbADAACMRtgBAABGI+wAAACjEXYA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.histplot(int_1hop_int_prop_list, bins=np.arange(0,1.02,0.02), label = \"interior\", stat=\"proportion\")\n",
    "sns.histplot(bnd_1hop_int_prop_list, bins=np.arange(0,1.02,0.02), label = \"boundary\", stat=\"proportion\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
