{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4a36ef7b",
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9f4b5aa0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYIAAAD8CAYAAAB6paOMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnv0lEQVR4nO3df3BV9Z3/8ecbk1DlVwUUxQtKDA1DWFwxgG1dRacIUkVsbY226IK7NI50xnb3u6tiocxYNq3D7K6iUsalVp2Wgl0J0yLijnXcrj8w+KukC0uCUAJOCyK0VEm49P39417wJrk3OfdHvD/O6zFzxnvO+XzO+VxeMe+ce88Pc3dERCS8+uV7ACIikl8qBCIiIadCICIScioEIiIhp0IgIhJyKgQiIiHXayEws9Vm9gcz25ZivZnZg2bWYmbvmNmkhHUzzWxHfN3duRy4ZEe5li5lK+kKckTwODCzh/XXAGPj0wLgUQAzOw14OL5+PHCzmY3PZrCSU4+jXEvV4yhbSUOvhcDdXwIO9dDkeuAJj3kV+LSZnQtMAVrcfZe7dwBr4m2lACjX0qVsJV1lOdjGecDehPm2+LJky6em2oiZLSD21wkDBgy4ZNy4cTkYmvRkwoQJtLS0UFtb2+3y8iFDhnDkyJGvAj+NL1KuRaSnbIEO4MmE+bSzVa6FZ+vWrQfd/axM+uaiEFiSZd7D8qTcfRWwCqC2ttabmppyMDTpye7du7n22mtJ9m/9xS9+kY0bN/6+y2LlWiR6ytbMPkrSJa1slWvhMbM9mfbNRSFoA0YlzEeA/UBFiuVSBCKRCMQyPLUI5VoqjqP/ZyVBLk4f3QDcGj8T4VLgiLu/B7wOjDWzMWZWAdTF20oRmD17NsAw5VqSDqP/ZyVBr0cEZvZTYBow3MzagCVAOYC7rwQ2ArOAFuBDYF58XdTMFgLPAacBq929uQ/eg2Tg5ptv5sUXX+TgwYNEIhGWLl3K8ePHAaivr2fWrFkA7SjXotNbtsARYBfKVuKsEG9Drc8cC4OZbXX32lxtT7kWBuVamrLJVVcWi4iEnAqBiEjIqRCIiIScCoGISMipEIiIhJwKgYhIyKkQiIiEnAqBiEjIqRCIiIScCoGISMipEIiIhJwKgYhIyKkQiIiEnAqBiEjIqRCIiIScCoGISMgFKgRmNtPMdphZi5ndnWT9/zOzt+LTNjM7YWZD4+t2m9lv4uv09IoCsmnTJqqrq6mqqqKhoSFZkxHKtfgoV0mbu/c4EXtkXStQSezh1m8D43tofx3wQsL8bmB4b/tJnC655BKXvhWNRr2ystJbW1u9vb3dJ06c6M3NzZ3aAE2uXIuKcg2vxFzTnYIcEUwBWtx9l7t3AGuA63tofzPw00BVSPJmy5YtVFVVUVlZSUVFBXV1dTQ2NvbURbkWAeUqmQhSCM4D9ibMt8WXdWNmZwAzgZ8nLHZgs5ltNbMFqXZiZgvMrMnMmg4cOBBgWJKNffv2MWrUqFPzkUiEffv2JW2rXIuHcpVMBCkElmRZqifeXwf8j7sfSlj2eXefBFwD3Glmlyfr6O6r3L3W3WvPOuusAMOSbMSOJDszSxY1oFyLhnKVTAQpBG3AqIT5CLA/Rds6uhxmuvv++H//ADxD7KMmybNIJMLevR8f6LW1tTFy5MhUzZVrkVCukokgheB1YKyZjTGzCmI/PBu6NjKzIcAVQGPCsgFmNujka+BqYFsuBi7ZmTx5Mjt37uTdd9+lo6ODNWvWMHv27G7tlGtxUa6SibLeGrh71MwWAs8RO4Notbs3m1l9fP3KeNMbgM3u/ueE7iOAZ+KHpmXAT9x9Uy7fgGSmrKyMFStWMGPGDE6cOMH8+fOpqalh5cpYnPX19SebKtciolwlE5bsM8V8q62t9aYmncKcb2a21d1rc7U95VoYlGtpyiZXXVksIhJyKgQiIiGnQiAiEnIqBCIiIadCICIScioEIiIhV5KFYNu2bZSVlfH888/neyifKHdn0qRJzJs3L99D6RPKVbmWkoLKNdPblvbllO1tbadPn+6XX355p2U7duzw73znOz516lQfPny4Dxw40C+66CK///77/ejRo1ntb/v27X7LLbf4uHHjfPDgwX766ad7dXW1f+tb3/L9+/dntW1392XLlvmNN97oY8aMccDPP//8lG0bGxu9X79+/uabb2a9X7K4rW2ySblmPm7lWhy5prvtQsk177/0k03Z/GC9/PLLDvj69es7Lf/nf/5nHzhwoN9yyy3+4IMP+qOPPupf/epXHfCJEyf6hx9+mPE+/+u//suvvPJKv+eee/zhhx/2H/7wh75w4UIfMGCAn3vuuf773/8+4227uwM+dOhQ/8IXvuBnnnlmj4XA3b2ystJvvPHGrPYZ32/B/MIotVwzGbdyLfxcM9l2IeSa91/6yaZsfrC+/vWv+7Bhw7yjo6PT8tdff90PHz7crf2iRYsc8Iceeijjfaaydu1aB/z73/9+VttpbW099bqmpqbXQrB48WIvLy/39957L6v9FtIvjFLLNZNxK9fCzzWTbRdCriX1HUE0GmX9+vVMnz6d8vLyTutqa2sZMmRItz433XQTEPucMtfOP/98AD744IOstlNZWZlW+2uuuYbjx4+zfv36rPZbKEox10zGrVwLP9dMtl0IuZZUIdi6dStHjx5lypTgd85ta2sDYMSIEVnv/9ixYxw8eJC2tjY2b97MN77xDQBmzZqV9bbTMWnSJPr378+LL774ie63r4Qp157GrVyLJ9d0tl0QuWZ6KNGXU6aHmqtXr3bAGxsbA7WPRqN+6aWXellZmW/fvj2jfSZ66KGHnNhDexzwCy64wJ966qmst5soyEdD7u4XXnihT5gwIat9USAfIYQhV/dg41auxZFrutvOd6693oa6mJx8ZN7QoUMDtb/rrrt49dVXWbZsGdXV1Vnvf86cOYwbN46jR4/y5ptvsmHDBvL1GL9hw4axe/fuvOw718KSa5BxK9fiyDXdbec910wrSF9Omf6F8YMf/MABf+mll3pte9999zngCxYsyGhfQbz99tteUVHhy5Yty9k2gx4RTJ482UeMGJHVviiQvxzDkGvQcSvX4so16LbznWvef+knmzL9wfrRj36U9FS0rpYsWeKAz5s3z//yl79ktK+gpk6d6pFIJGfbC+NHQ6WeazrjVq7Fk2s62853roG+LDazmWa2w8xazOzuJOunmdkRM3srPi0O2jeXJkyYAMDOnTtTtlm6dClLly7l1ltv5bHHHuvpwd458dFHH3Ho0KHeG+ZQe3s7e/fuPfXvkcqmTZuorq6mqqqKhoaGZE0GKdfkcpVrOuNWrsWTazrbDpprn+qtUhB7PGUrUAlUAG8D47u0mQb8IpO+yaZM/8KIRqM+ePBg//KXv5x0/dKlSx3wuXPn+okTJzLaRzKpzv994YUXvF+/fn7VVVflbF9BjgheeeUVB/zRRx9N2SYajXplZaW3trZ6e3u7T5w40Zubmzu1AXYo1+5ylWu641auudGXuWay7SC5BkEff1k8BWhx910AZrYGuB74bR/3Tdtpp53Gl770JRobG2lvb6d///6n1j388MMsWbKE0aNH84Uv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\n",
      "text/plain": [
       "<Figure size 432x288 with 6 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(1, 7):\n",
    "    plt.subplot(2, 3, i)\n",
    "    plt.text(0.5, 0.5, str((2, 3, i)),\n",
    "             fontsize=18, ha='center')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "439e0ff4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e68354c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl(df):\n",
    "    acctual_influence_1 = df1['actual influence'].values\n",
    "    predict_influence_1 = df1['predict influence'].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",
    "    sns.set_theme()\n",
    "    sns.set_style(\"dark\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    plt.axis('square')\n",
    "    plt.xlabel('Act. Influence')\n",
    "    plt.ylabel('Pred. Influence')\n",
    "    plt.ylim(low_limit, up_limit)\n",
    "    plt.xlim(low_limit, up_limit)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d11529c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl(df):\n",
    "    acctual_influence_1 = df['actual influence'].values\n",
    "    predict_influence_1 = df['predict influence'].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",
    "    sns.set_theme()\n",
    "    sns.set_style(\"whilte\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax.axis('square')\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax.set_ylim(low_limit, up_limit)\n",
    "    ax.set_xlim(low_limit, up_limit)\n",
    "#     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "0d7d7f7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "df0 = pd.read_csv('node_feature_2/reddit_node_feature_influence.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b402fe46",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-6.411108241155671, 6.411108241155671)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXkAAAEcCAYAAAAiOsTUAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAAyUUlEQVR4nO3deVxU5f4H8A8DjIqECIICkuUS7oKBqKAImigipGlSqamVqKFeb6Zom2A3xSxTwqhbaYvlT1PGEsR9IRcERck1Ra8SqyIuOMYyM78/uJzryDY422H4vF8vXi9mzpnzfOfAfOaZ5zxzjplKpVKBiIhMksTYBRARkf4w5ImITBhDnojIhDHkiYhMGEOeiMiEMeSJiEyYQUM+NjYW8+fPr3V5QEAAjhw5AgCIj4/HO++8Y6jSqvnrr7/g5uaGioqKBj9WpVJh0aJF8PLywrhx4/RQnX55eHggOztbo3VPnDiB4cOHw8PDA3v27MGkSZOwefNmPVdoPG5ubrh27ZqxyzBp3Me6VW/IBwQEoHfv3vDw8ICPjw8iIyNx//59vRc2Y8YM/Otf/wKgWeDGxsbCzc0NO3bsEO6rqKiAm5sb/vrrL73X+7ATJ07g8OHDOHjwIH755RettrV161a89NJLOqpMMxkZGXB1ddVo3TVr1uCVV15BRkYGhg0bpufK9Cs1NRVdu3aFh4cHPDw8EBgYiC1bthi8jvPnz2Ps2LHo06cPxo4di/Pnz9e67ooVK+Dn54e+ffvC398fX3zxhbAsPT1deC5VP25ubti5c6ewTnZ2NsLDw+Hh4QFvb2+sWLFCr89NjFQqFT7++GN4e3sL+6Curw8dPXoUI0aMQJ8+fTBp0iTk5ORovK2//voLkyZNQp8+fTBixAihUwsAhYWFmDFjBnx9fWvMraSkJISFhQntakqjnnx8fDwyMjIgk8lw7tw5fPXVVxo3YEi2trZYs2YNFAqFUevIycmBi4sLrKysjFoHgMf6JNIQubm56NKli17bMCRHR0dkZGTg5MmTWLx4Md577z1cuXLFYO2XlZVh1qxZCAkJQVpaGp5//nnMmjULZWVlNa4/btw47NixAydPnsTGjRuxfft27Nq1CwDg6emJjIwM4Sc+Ph5WVlYYNGiQ0NbUqVPRv39/HD58GIcOHUJISIjBnqtY/N///R/27NmDbdu24ddff8WBAwewcePGGte9desWIiIiMHfuXBw/fhw9e/bEvHnzNN7WW2+9he7duyM1NRXz5s3DnDlzcOvWLQCARCLBoEGDEBsbW2Pbtra2mDx5Mt54440GPb8GDdc4ODjA19dXrWdx6tQphIWFwdPTEyEhIUhNTRWWZWdnY+LEifDw8MDUqVNRXFystj2ZTAZ/f394e3ur9UAA9aGdiRMnAgC8vLzg4eGBjIyMGuvz9fWFpaUlfv311xqX37t3DwsWLED//v3h7++PtWvXQqlUAgAUCgViYmLg7e2NoUOH4uDBg9Ueu3jxYvj6+mLQoEFYtWpVjW8mmzdvxrvvvotTp07Bw8MDa9asAQDs378foaGh8PT0RFhYGC5cuCA85quvvsKwYcPg4eGBoKAg7N69GwCQlZWFDz74QNiWp6cnAFQbEnm0t+/m5oYNGzZg+PDhGD58eL3tP+rhj8uRkZGIiorC9OnT4eHhgfHjx+P69esAgGHDhiE7OxszZsyAh4dHtSB6dHju0U9kde3TqucUExMDLy8vBAQEqP1Nbt++jUWLFsHX1xdeXl6YNWuWsKwhz7U2ZmZm8PPzQ6tWrXDx4kW1ZUeOHMHw4cPh5eWFqKgooaemVCqxdu1a+Pv7Y8CAAViwYAHu3bvXoHaPHz+OiooKvPrqq5BKpZg8eTJUKhWOHTtW4/odO3ZU60xIJJJahzpkMhlGjBghrJ+QkABHR0dMnToVVlZWaNasGbp27apRnampqRg8eDDi4+Ph7e2NgIAA4XV36tQp+Pj4qL0+du/ejdGjRwMAMjMzMWHCBHh6esLX1xfR0dG1vonV97+elZWFqVOnol+/fggMDERSUpJG9T9MJpNh2rRpaNeuHdq2bYupU6ciISGhxnV3796NLl26YOTIkWjWrBlmz56NCxcuICsrq95tXb16FWfPnsXs2bPRvHlzBAYG4plnnhE+WbVp0wavvPIKevXqVWPbAwcORFBQENq2bdug59egkM/Pz0dKSgqefPJJAEBBQQHCw8Mxc+ZMHD9+HAsXLlR7Z5o/fz569OiB1NRUzJo1S23HXb58GVFRUVixYgVSUlJw+/Zt5Ofn19jujz/+CABIS0tDRkYGPDw8alzPzMwMc+fOxeeff47y8vJqy5cuXYp79+5hz549+OGHH7Bt2zbh4/imTZuwf/9+yGQybNmyBcnJyWqPXbhwISwsLLBr1y7IZDIcPny4xrHn8ePHIyoqCu7u7sjIyMCcOXNw9uxZLF68GNHR0UhNTcWECRPUemeurq7YsGEDTpw4gYiICLz99tsoLCxEp06d1LaVnp5e59/nYXv27MGmTZuQlJRUb/v1SUxMREREBNLS0vDkk09i1apVQhvOzs7CJz2pVKpxfUD9+zQzMxNPP/00jh07htdffx3vvPOOEKgLFizAgwcPkJiYiCNHjmDKlCkAoPVzraJUKrF3714UFxejQ4cOassOHDiAX375Bdu2bcOOHTuQkpICoDKAEhIS8P3332PPnj2Qy+WIjo4WHufp6VnrT9Wn48uXL8PNzQ1mZmbC49zc3HD58uVaa/3qq6/g4eGBwYMHQy6XC2H6sAcPHiA5ORnPP/+8cN+pU6fg4uKC119/Hd7e3pg0aVK1N7S63Lx5E8XFxUhJScHy5cvx/vvv48qVK3B3d0eLFi3U3ph+++03oS6JRIJFixbh2LFj2LhxI44ePYqffvpJ43aryOVyTJs2DcHBwThy5Ag+/fRTREVF4dKlS8J+qWufV7l06ZLam1vXrl2FbTzq0qVLcHNzE25bWVnhySefFP4+dW3r8uXLcHV1hbW1tdryuv62uqBRyL/55pvw8PCAn58f7OzsMGfOHADAtm3bMHjwYPj5+UEikcDHxwc9e/bEwYMHkZubiz/++ANz586FVCoVemNVkpOTMWTIEHh5eUEqlWLu3LmQSLQ/Djx06FDY2dlVC2CFQoGkpCS89dZbsLa2Rvv27TF16lSh97Fjxw68+uqrcHJygq2tLcLDw4XH3rx5E4cOHcLixYthZWUFe3t7TJkyBYmJiRrVtGnTJkyYMAF9+vSBubk5xowZA0tLS5w6dQoAMHLkSLRt2xYSiQRBQUHo0KEDMjMztdoP06dPh62tLZo3b15v+/V57rnn0Lt3b1hYWCAkJKTOMWJNabJPnZ2d8eKLLwo137hxAzdv3kRhYSEOHTqEqKgotGrVCpaWlujXrx+A+vd1fQoLC+Hp6YnevXsjIiICkZGR6N69u9o6b7zxBmxsbODs7Axvb2/hk8Jvv/2GKVOmwNXVFS1btsQ///lPJCUlCZ9c0tPTa/2ZPn06AOD+/ft44okn1Nqztrau8zjY9OnTcfLkSSQkJCA0NFQtRKrs3LkTrVu3FvYTUNlJS0pKwqRJk5CSkgI/P78GvyFWvb779esHPz8/4ZjYqFGjsH37dgBASUkJDh06hFGjRgEAevbsCXd3d1hYWKB9+/aYMGEC0tLSNG6zyoEDB+Di4oIXXngBFhYW6NGjBwIDA4We8fTp0+vc51XkcrnaPnviiScgl8trHJeXy+V1/n3q2lZNf9snnnhC78c4LTRZKS4uDgMHDsTx48fx1ltvobi4GDY2NsjNzUVycjL2798vrFtRUQFvb28UFhbCxsZG7aOks7Mz8vLyAFS+mNq1aycss7Kygq2trU6e1D/+8Q8sWrQIoaGhwn3FxcUoLy+Hs7OzWj0FBQVCPU5OTmrLquTm5qKiogK+vr7CfUqlUm39uuTm5kImkwmfSACgvLwchYWFACo/4q1bt044gCOXy6sNbTXUw7XV13592rRpI/zevHlzyOVyrWqrqqm+ffpwuy1atABQuW/u3LmDVq1aoVWrVjVuV5vn6ujoiEOHDqGsrAwrV67EsWPHhE8JVRwcHNTqqnqRFhYWwsXFRVjm4uKCiooKFBUVafwRu2XLligpKVG77/79+2jZsmWdjzMzM0P37t3x+++/IzY2FosWLVJbLpPJ8Pzzz6t9QmjWrBn69u0LPz8/AMBrr72GL774AleuXNFo2Kam13fVfh49ejTCwsIQFRWF3bt3o3v37sK+uXr1KpYvX44zZ87gwYMHUCgU6NGjR73tPSonJweZmZlqvXKFQtHg4wpWVlZqQVtSUgIrKyu1ffXwunX9feraVk1/25KSknr/ttrSKOSr9OvXD2PHjkVMTAzWrl0LJycnhIaG4sMPP6y2bk5ODu7evQu5XC78I+Tm5go7ztHRURjHAio/Tt6+fbvGdmva2XXx8fFBhw4d1D4Ctm7dGpaWlsjNzUXnzp0BAHl5ecKLz8HBQXgDqlpWpV27dpBKpTh27BgsLBq0ywBUBu6MGTMwc+bMastycnLw7rvvYv369fDw8IC5ubnam1NNz71FixZ48OCBcPvmzZvV1nn4cXW1r08tWrTA33//Ldx+uE5t9mm7du1w584d3L17FzY2NmrLdPVcpVIp5s+fjxEjRmDPnj0azRxydHRUm2mRm5sLCwsL2NvbA0Ctw4wAEB4ejhkzZqBz58749ttvoVKphL/hxYsX8fLLL2tUd0VFhXDMpEpeXh6OHz+uNnQEVA4DnTx5UqPt1uTR13deXp5wEL5z585wdnbGoUOHsH37dgQHBwuPW7JkCbp3745PPvkE1tbWWL9+vdqMn4fV9b/u5OQELy8vrFu3rsbHxsfH48svv6y1/qpje126dMGFCxfQu3dvAMCFCxdqnUzQpUsXtWFnuVyO69evC5lS17Y6d+6M7OxslJSUCL39CxcuqO0bfWjw+Mirr76KI0eO4Pz58wgJCcH+/fuRkpIChUKB0tJSpKamIj8/Hy4uLujZsydiY2NRVlaG9PR0tR5/YGAgDhw4gPT0dJSVlWHNmjXCQdBH2dnZQSKRaDx3G6jszX/99dfCbXNzc4wYMQKrVq1CSUkJcnJysG7dOuFdf+TIkfjhhx+Qn5+PO3fuqM0gcnR0hI+PD5YvX46SkhIolUpcv34dx48f16iW8ePHY+PGjTh9+jRUKhXkcjkOHDiAkpISPHjwAGZmZrCzswMAbNmyRW080N7eHgUFBWofobt164bdu3fjwYMHuHbtWr3TNOtqX5+6deuGtLQ05Obm4t69e2ovOG32qaOjIwYPHoyoqCjcuXMH5eXlwsf9+p5rZGQkIiMjNapfKpVi2rRpiIuL02j94OBgfPfdd8jOzsb9+/exatUqjBw5UngTe3imy6M/M2bMAFDZkTI3N8f333+PsrIy4RNJ//79q7WnVCqxceNG3LlzByqVCpmZmfjpp58wYMAAtfW2bdsGDw8P4VhalZCQEJw+fRpHjhyBQqHAd999h9atW6Njx44a76uHX98HDhzAiBEj1PbH999/j7S0NLX7q3q+LVu2RFZWFn7++edat1/X//qQIUPwn//8BzKZDOXl5SgvL0dmZqbQeZwxY0ad+7xKaGgo1q1bh4KCAhQUFGDdunUYM2ZMjfU899xzuHTpEnbu3InS0lLExcXBzc0NnTp1qndbTz/9NLp164a4uDiUlpZi9+7duHjxIgIDA4Xtl5aWCq/1srIylJaWCsuqMraiogJKpRKlpaU1Hnt8VIND3s7ODqGhoUJPfu3atfjyyy8xYMAA+Pn54ZtvvhHC+pNPPsHp06fh7e2NuLg4tYM+Xbp0wfvvv4/58+dj0KBBsLGxURu+eViLFi0wY8YMvPTSS/D09NRofPXZZ58V3k2rvPfee2jRogWGDRuGl19+GcHBwXjhhRcAAC+++CJ8fX0RGhqKMWPGCLNSqqxYsQLl5eUICgqCl5cX5syZgxs3bmi0z3r16oWlS5ciOjoaXl5eGD58OLZu3Qqg8t192rRpCAsLw8CBA/Hnn3+ib9++wmP79++Pzp07w9fXF97e3gAq32gtLS0xcOBALFy4sMYDbZq2r08+Pj4ICgpCSEgIxo4dC39/f7Xl2uzTFStWwMLCAiNHjsTAgQPx3XffAaj/uebl5ant3/q88MILyM3Nxb59+zRaNyQkBBMnTsTQoUMhlUrx3nvvadwWUPnGEhcXh23btsHT0xNbtmxBXFyccFD7119/Fca2gcrZHs899xz69u2Lt99+GxMnTqw2h7pqqOZRHTt2xMcff4wPPvgAXl5e2Lt3L7744guhrfr2VZs2bWBjY4NBgwZh/vz5WLJkiRB2QGXIHz9+HP379xc6MUDlAfft27ejb9++eO+99xAUFFRrG3X9r1tbW+Obb75BUlISBg0aBF9fX6xcubLBB9nDwsLg7++P0aNHY/To0fDz80NYWJiwfNSoUcKxOzs7O8TGxmLVqlXw8vJCZmYmPv30U4239emnn+LMmTPw8vLCypUrsWbNGrV9U/WdJKCy4/lwhm3btg29e/fGkiVLkJ6ejt69e2v0/2XGi4ZQU1FWVobQ0FD8+uuvsLS0NHY5olbfvkpNTcXbb7+NQ4cOGaE6aoiGDzATNVJSqVTtG9FUO+4r08ETlBERmTAO1xARmTD25ImITBhDnojIhDHkiYhMGGfX6EBx8X0olTy0QaQrcvl93Lt3Fy1bWqFDB5f6H0C1YsjrgFKpYsgT6UhJyT3cuXMbzZs3R8uWNvU/gOrEkEflV4k/+ugjHD16FM2aNYO7uzuWLl1q7LKImpyHA97Ork2Dz1tF1THkAXz88cdo1qwZdu7cCTMzsxpP+EVE+sWA148mH/L379+HTCbDwYMHhX+qh09xS0T6x4DXnyY/uyY7Oxu2trb4/PPPMXbsWEyaNKlBV2AiIu0w4PWryYd8RUUFsrOz0b17d2zduhXz58/H7Nmz9X4aXiJiwBtCkw95Z2dnWFhYCCfu79OnD1q3bo2rV68auTIi08aAN4wmH/J2dnbw9vbG4cOHAVRemqyoqKjaxZuJSHcY8IbDE5Shclx+8eLFuH37NiwsLPCPf/xDuO6lJoqKSjhPnkhDDQl4icQM9vbVL0xOmmPI6wBDnkgzDe3BM+S11+SHa4jIMDhEYxwMeSLSOwa88TDkiUivGPDGxZAnIr1hwBsfQ56I9IIBLw4MeSLSOQa8eDDkiUinGPDiwpAnIp1hwIsPQ56IdIIBL04MeSLSGgNevBjyRKQVBry4MeSJ6LEx4MWPIU9Ej4UB3zgw5ImowRjwjQdDnogahAHfuDDkiUhjDPjGhyFPRBphwDdODHkiqhcDvvFiyBNRnRjwjRtDnohqxYBv/BjyRFQjBrxpYMgTUTUMeNPBkCciNQx408KQJyIBA970MOSJCAAD3lQx5B/y+eefw83NDX/++aexSyEyKAa86WLI/9fZs2dx6tQpODs7G7sUIoNiwJs2hjyAsrIyREdH44MPPuA/ODUpDHjTx5AHsHr1aoSEhMDV1dXYpRAZDAO+aWjyIZ+RkYE//vgDL7/8srFLITIYBnzT0eRDPi0tDVeuXMHQoUMREBCA/Px8vPbaa/j999+NXRqRXjDgmxYzlUqlMnYRYhIQEID4+Hg888wzGj+mqKgESiV3I4nf/fsluH27uNEEvERiBnt7a2OX0ag1+Z48UVPR2AKedIM9eR1gT57ErrEGPHvy2mNPnsjENdaAJ91gyBOZMAY8MeSJTBQDngCGPJFJYsBTFYY8kYlhwNPDGPJEJoQBT49iyBOZCAY81YQhT2QCGPBUG4Y8USPHgKe6MOSJGjEGPNWHIU/USDHgSRMMeaJGiAFPmmLIEzUyDHhqCIY8USPCgKeGYsgTNRIMeHocDHmiRoABT4+LIU8kcgx40gZDnkjEGPCkLYY8kUgx4EkXGPJEIsSAJ10RdcirVCps2rQJkydPxujRowEAaWlpSEpKMnJlRPrDgCddEnXIr169Gr/88gsmTJiAvLw8AEC7du3w9ddfG7kyIv1gwJOuiTrkExISEB8fj1GjRgn/7O3bt0d2draRKyPSPQY86YOoQ16hUKBly5YAIPzD379/H1ZWVsYsi0jnGPCkL6IOeT8/PyxbtgxlZWUAKsfoV69eDX9/fyNXRqQ7DHjSJzOVSqUydhG1KSkpwYIFC5CSkoKKigo0a9YMPj4+iImJgbW1tU7aKC4uxoIFC3D9+nVIpVJ06NAB0dHRsLOz03gbRUUlUCpFuxtJxBjwdZNIzGBvr5vXelMl6pCvUlRUhJycHDg5OcHBwUGn2759+zYuXrwIb29vAEBMTAzu3LmDjz76qAH1MeSp4Rjw9WPIa0/UwzW///47rl69Cnt7e/Tu3RsODg64cuUKDh8+rLM2bG1thYAHAHd3d+Tm5ups+0Q1YcCToYg65KOjo4UDr1VatmyJ6OhovbSnVCrx888/IyAgQC/bJwIY8GRYog75oqIiODo6qt3n6OiIGzdu6KW9pUuXwsrKChMnTtTL9okY8GRoog55V1dXHD16VO2+1NRUtG/fXudtxcTE4Nq1a/jss88gkYh6t1AjxYAnY7AwdgF1iYiIwOzZszFu3Di4uroiOzsbW7dubdBBUU2sWrUKZ86cwVdffQWpVKrTbRMBDHgyHtHPrsnMzMQvv/yC/Px8tGvXDuPGjUPv3r11tv1Lly4hODgYTz31FJo3bw6g8lu1cXFxGm+Ds2uoLgz4x8fZNdoTfcg3Bgx5qg0DXjsMee2JerimrKwMCQkJOH/+PORyudqyFStWGKkqIs0w4EkMRB3ykZGRuHDhAvz9/dGmTRtjl0OkMQY8iYWoQz4lJQV79+6FjY2NsUsh0hgDnsRE1HMFnZychJOTETUGDHgSG1H35J9//nnMmjULkydPhr29vdqyAQMGGKkqopqVlNzDnTu3GfAkKqKeXVPb6QXMzMywd+9eA1dTO86uIQa8fnB2jfZEHfKNBUO+aWPA6w9DXnuiHpMHgPLycqSnpwsX75bL5dWmUxIZCwOexE7UY/IXL17EzJkzIZVKUVBQgKCgIKSlpSEhIQGfffaZscujJo4BT42BqHvyS5YswZw5c5CcnAwLi8r3Iy8vL5w4ccLIlVFTx4CnxkLUIX/58mWEhoYC+N+FvK2srFBaWmrMsqiJY8BTYyLqkHdxccGZM2fU7svMzMSTTz5ppIqoqWPAU2Mj6jH5uXPnIjw8HGFhYSgvL8eXX36JjRs3YunSpcYujZogBjw1RqKfQnn27Fls3rwZubm5aNeuHV588UX07NnT2GWp4RRK08eANw5OodSe6EO+MWDImzYGvPEw5LUn6uGa1atX17ps7ty5BqyEmioGPDV2og75/Px8tds3btxAWloahg0bZqSKqClhwJMpEHXIL1u2rNp9hw4dQmJiohGqoaaEAU+mQtRTKGvi6+uLPXv2GLsMMmEMeDIlou7JZ2dnq91+8OABtm/fDicnJyNVRKaOAU+mRtQh/9xzz8HMzAxVE4BatGiBbt26Yfny5UaujBozpVKFpGPXkJVzB51cWiFoQAdIzMwY8GSSRB3yFy5cMHYJZIKSjl3D1kNXAACns4oAAEN62zPgySQ1ujF5Im1l5dxRu33xehEDnkyW6Hryfn5+Gr3IDhw4oP9iyCR1cmkl9OABwMnWggFPJkt0If/xxx8buwQycUEDOgCo7ME72VrgOU8nBjyZLNGd1uDFF1/Epk2bAACff/45IiIi9N7m1atXERkZidu3b8PW1hYxMTF46qmnNH48T2vQ+PAga+PA0xpoT3Qh369fP6SkpKBZs2bo27cvTp48qfc2J0+ejBdeeAGhoaHYtm0btmzZgu+//17jxzPkxa+iQolVm07hz7/uQKlSobmlBIN62WP80B4wl/DQlFgx5LUnupBftGgRjh49ChcXF5w6dQru7u41rrdhwwadtFdUVITAwECkpqbC3NwcCoUC3t7e2LVrF+zs7DTcBkNerOTycsyJTUFtf55Q3w4I9e1k2KJIYwx57YluTH7ZsmVIT09HTk4O/vjjD4wbN06v7eXl5aFt27YwNzcHAJibm8PR0RF5eXkahzyJ17y1h2sNeADYcSybIU8mTXQhDwCenp7w9PREeXk5xowZY+xyqJFSKlUor1DWuU5ZhRLbj/xH+EKUGNX25S0iTYgy5KuMGzcOV65cwYULFyCXy6st0wUnJycUFBRAoVAIwzWFhYU8dYIJSDp2TaP1qr4YFTzwKT1W8/hq+vKWWGsl8RF1yMfHxyMuLg5du3ZF8+bNhfvNzMx0FvL29vbo1q0btm/fjtDQUGzfvh3dunXjUI0JePRLT7pa19AerU3MtZL4iDrkv/vuO2zevBldu3bVaztLlixBZGQk1q5dCxsbG8TExOi1PTIMV4fmOJ2l2bqdXFrptxgtPPrlLTHXSuIj6pBv3rw5OnbsqPd2OnXqhM2bN+u9HTKckpJ78OrcAhUVbZFXXIGCW3LkFz+otl47OysM7NlO+IKUGFXV9vCYPJGmRDeF8mEymQwnT55EREQE2rRpo7ZMIqK5zZxCqTu6OMhY0xedth/5jzCuXaX7U63xzwnuPIgpYpxCqT1R9+QjIyMBQK2XrVKpYGZmhvPnzxurLNKjxz3IWPXmUNupCoIGdMCRM3nIv/W/3ryluYQBTyZP1CG/d+9eY5dABva4BxkffnM4C8DGxgbBAx2F5RIzMwzs6aTWm+fYNjUFog55FxcXY5dABlbbQcb6hnEuXi9S205Wzt1q2+bYNjVFogz51atX17vO3LlzDVAJGVptQVzXME5JyT042Vrg7EPbqamXLjEz4/xyanJEGfL5+fnGLoGMpLYgrm0Yp+og63OeTrCxsUFWzl320okeIurZNY0FZ9fo36OzY8YO7shL9jUBnF2jPVH25Ike9egwzuBedgx4Ig2wJ68D7MkbFi/40XSwJ6899uSpUWlIwPPsjUQMeWpEGtqD59kbiQDxnBugATj7pul5nCEanr2RqJGGfFBQkLFLIAN63DH4R+fK8xuu1BQ1yuGaxMREY5dABqLNQVZ+w5WIs2t0grNr9IOzaIiza7Qnup68Jqc0AHhaA1PHgCfSDdGF/MMHVUtLS7Fr1y707NkTLi4uyM3NxR9//IHhw4cbsULSNwY8ke6Ierhm3rx5GDFiBAIDA4X7du3aheTkZHz66adGrEwdh2t0hwFPD+NwjfZEHfLPPvssjh8/DnNzc+E+hUKBfv364cSJE0asTB1DXjcY8PQohrz2RD2FskOHDtiwYYPafT/99BOefPJJI1VE+sKAJ9IPUffkz507h4iICFRUVKBt27YoKCiAhYUFYmNj0aNHD2OXJ2BPXjsMeKoNe/LaE3XIA0B5eTlOnz6NwsJCODg4wN3dHZaWlsYuSw1D/vEx4KkuDHntiXq45lFeXl4oLy+HXC43dimkAwx4Iv0T3RTKh128eBEzZ86EVCpFQUEBgoKCkJaWhoSEBHz22WfGLo+0wIAnMgxR9+SXLFmCOXPmIDk5GRYWle9HXl5eoppZQw3HgCcyHFH35C9fvozQ0FAAEILAysoKpaWlOtl+VFQUjh49CqlUCisrK7zzzjvo1auXTrZNNWPAExmWqHvyLi4uOHPmjNp9mZmZOptCOXjwYPz222/49ddfER4ejnnz5ulku1QzBjyR4Ym6Jz937lyEh4cjLCwM5eXl+PLLL7Fx40YsXbpUJ9v39/cXfnd3d0d+fj6USiUkElG/9zVKDHgi4xB1mvn7++Pf//43bt26BS8vL+Tk5CA2Nha+vr46b2vDhg0YMmQIA14PGPBExiPaefIKhQKBgYFISkqCVCp9rG2MGTMGubm5NS47cuSIcLqExMRErFmzBhs2bECbNm0a3A7nydeOAU/a4Dx57Yl2uMbc3Bzm5uYoLS197JBPSEiod53du3dj1apVWL9+/WMFPNWOAU9kfKLtyQOVQyj79u1DeHg42rVrpxYSrq6uWm9///79WLp0KdatW4cOHR7/qkHsyVfHgCddYE9ee6IO+a5du9Z4v5mZGc6fP6/19vv37w9LS0vY2dkJ961fvx6tW7du0HYY8uoY8KQrDHntiTrkGwuG/P8w4EmXGPLaE+WY/IMHD/DFF1/gzz//RI8ePRAeHv7Y4/JkOAx4IvER5XzB6Oho7N+/Hx07dsTOnTsRExNj7JKoHgx4InES5XCNr68vtm7dCkdHR+Tl5eGVV17Bvn37jF1WrZr6cA0DnvSFwzXaE2VPXi6Xw9HREQDg5OSEkpISI1dEtWHAE4mbKMfkFQoFjh07hqoPGRUVFWq3AWDAgAHGKo/+iwFPJH6iHK4JCAioc7mZmRn27t1roGrq1xSHaxjwZAgcrtGeKEO+sWlqIc+AJ0NhyGtPlGPyJF4MeKLGhSFPGmPAEzU+DHnSCAOeqHFiyFO9GPBEjRdDnurEgCdq3BjyVCsGPFHjx5CnGjHgiUwDQ56qYcATmQ6GPKlhwBOZFoY8CRjwRKaHIU8AGPBEpoohTwx4IhPGkG/iGPBEpo0h34Qx4IlMH0O+iWLAEzUNDPkmiAFP1HQw5JsYBjxR08KQb0IY8ERND0MeQGpqKrp164Yff/zR2KXoDQOeqGlq8iFfUlKClStXYvDgwcYuRW8Y8ERNV5MP+eXLl+O1115D69atjV2KXjDgiZq2Jh3yBw8exN27dzFixAhjl6IXDHgisjB2Afo0ZswY5Obm1rgsOTkZn3zyCdatW2fgqgyDAU9EAGCmUqlUxi7CGNLT0zF79my0aNECAFBcXAypVIpJkyYhIiKiQdsqKiqBUime3ciAJ1MhkZjB3t7a2GU0ak025B8VGRmJnj17YuLEiQ1+rJhCngFPpoQhr70mPSZvahjwRPQo9uR1QAw9eQY8mSL25LXHnrwJYMATUW0Y8o0cA56I6sKQb8QY8ERUH4Z8I8WAJyJNMOQbIQY8EWmKId/IMOCJqCEY8o0IA56IGsqkz13TGCiVKiQdu4asnDvo5NIKQQM6QFJDeDPgiehxMOSNLOnYNWw9dAUAcDqrCAAQPPAptXUY8ET0uDhcY2RZOXfqvM2AJyJtMOSNrJNLq1pvM+CJSFscrjGyoAEdAEBtTB5gwBORbvAEZTqg6xOUMeCJKvEEZdrjcI3IMOCJSJcY8iLCgCciXWPIiwQDnoj0gSEvAgx4ItIXhryRMeCJSJ8Y8kbEgCcifWPIGwkDnogMgSFvBAx4IjIUhryBMeCJyJAY8gbEgCciQ2PIGwgDnoiMgSFvAAx4IjKWJn8Wyh9++AEbNmyApaUlzM3NIZPJdLp9BjwRGVOTDvldu3YhOTkZv/zyC6ytrXHjxg2dbp8BT0TG1qSHa7799ltERETA2rryVKYODg462zYDnojEoEmHfFZWFk6fPo2wsDCMHTsWmzZt0sl2GfBEJBYmPVwzZswY5Obm1rjsyJEjUCgUyMvLw08//YTi4mK89NJLePrpp+Hl5fXYbTLgiUhMTDrkExIS6lzu7OyM4OBgSCQS2NvbY+DAgcjMzHzskGfAE5HYNOnhmuDgYKSkpAAA5HI5Tpw4ga5duz7WthjwRCRGTfoar3///Tfee+89nDt3DgAQGhqK6dOnN3g72dkFKCoqYsAT6Riv8aq9Jh3yunLu3CVIJOYMeCIdY8hrz6TH5A2lZUsrtGxpw4An0jGJhK8pbbEnT0Rkwpr0gVciIlPHkCciMmEMeSIiE8aQJyIyYQx5IiITxpAnIjJhDHkiIhPGkCciMmEMeSIiE8bTGohMZGQkjhw5gtatWwMARowYgZkzZ9a47qZNm/Dvf/8bKpUKgwcPxrvvvguJxDDv21FRUTh69CikUimsrKzwzjvvoFevXtXWS01NxfTp0/HUU08BAKRSKTZv3qz3+q5evYrIyEjcvn0btra2iImJEWqoolAo8OGHHyIlJQVmZmaYPn06xo8fr/faqhQXF2PBggW4fv06pFIpOnTogOjoaNjZ2amtFxsbi59++gmOjo4AgL59++KDDz4wWJ0AEBAQAKlUimbNmgEA5s+fj0GDBqmtY+z9SbVQkagsXLhQ9cMPP9S73vXr11WDBg1SFRUVqRQKhWratGmqhIQE/Rf4X/v27VOVlZUJvw8dOrTG9Y4dO6YaM2aMweqqMmnSJJVMJlOpVCqVTCZTTZo0qdo6CQkJqmnTpqkUCoWqqKhINWjQIFV2drbBaiwuLlYdO3ZMuL18+XLVokWLqq23Zs0a1fLlyw1WV038/f1VFy9erHMdY+9PqhmHaxqpnTt3YtiwYbCzs4NEIsH48eORlJRksPb9/f1haWkJAHB3d0d+fj6USqXB2q9LUVERzp07h+DgYACV1w04d+4cbt26pbZeUlISxo8fD4lEAjs7OwwbNgzJyckGq9PW1hbe3t7CbXd391qvZNYYGHt/Us0Y8iK0bt06jB49GrNmzUJWVlaN6+Tl5cHZ2Vm47ezsjLy8PEOVqGbDhg0YMmRIrUNF//nPfzBmzBiMHz++3qt16UJeXh7atm0Lc3NzAIC5uTkcHR2r7Z9H96GTkxPy8/P1Xl9NlEolfv75ZwQEBNS4PDExEaNHj8a0adOQkZFh4OoqzZ8/H6NHj8aSJUtw9+7dasvFtD/pfzgmb2D1XXd23rx5cHBwgEQigUwmw+uvv449e/YIgSWWOqvqSUxMxG+//YYNGzbUuG6PHj1w8OBBPPHEE8jOzsbUqVPRtm1bDBw4UG+1N0ZLly6FlZUVJk6cWG1ZWFgYZsyYAUtLSxw+fBizZs1CUlKScNzGEDZs2AAnJyeUlZXhX//6F6Kjo7Fy5UqDtU+PjyFvYPX1ZNu2bSv8/vzzz2PZsmXIz8+Hi4uL2npOTk5qIZybmwsnJyeD1QkAu3fvxqpVq7B+/Xq0adOmxnWsrf93wQdXV1cMGzYMJ0+e1GvIOzk5oaCgAAqFAubm5lAoFCgsLKy2f6r2Ye/evQFU74kaSkxMDK5du4b4+PgaPw05ODgIv/v4+MDJyQmXLl1Cv379DFZj1b6TSqV4+eWXa5wMIJb9Seo4XCMyBQUFwu8pKSmQSCRqwV8lMDAQe/bswa1bt6BUKrF582aMHDnSYHXu378fy5YtwzfffIP27dvXul5hYSFU/71kwe3bt3H48OHHvo6upuzt7dGtWzds374dALB9+3Z069at2qyVESNGYPPmzVAqlbh16xb27NmDwMBAvdb2qFWrVuHMmTOIi4uDVCqtcZ2H/yfOnz+PnJwcPP3004YqEXK5HPfu3QMAqFQqJCUloVu3btXWE8P+pOp40RCRmTJlCoqKimBmZgZra2ssWLAA7u7uAIDVq1fD0dERL730EgBg48aN+PrrrwFU9vDef/99gw3r9O/fH5aWlmrBuX79erRu3Vqtzh9//BE///wzLCwsoFAoEBoaijfeeEPv9WVlZSEyMhJ3796FjY0NYmJi0LFjR7zxxhuYM2cOevXqBYVCgejoaBw+fBgA8MYbb2DChAl6r63KpUuXEBwcjKeeegrNmzcHALRv3x5xcXFqdS5cuBBnz56FRCKBpaUl5syZAz8/P4PVmZ2djdmzZ0OhUECpVKJTp05499134ejoKKr9STVjyBMRmTAO1xARmTCGPBGRCWPIExGZMIY8EZEJY8gTEZkwfhmKmowrV67gn//8J65du4Z58+bh3LlzaNu2LebNm2fs0oj0hj150ptJkybBy8sLZWVlGq2/detW4TsAmnJzc8O1a9c0Wvfrr79Gv379kJGRgcmTJzeoHaLGiiFPevHXX38hPT0dZmZm2Lt3r7HLAVB56ocuXboYuwwig2LIk17IZDL06dMHY8aMgUwmU1uWl5eHiIgI9O/fH97e3oiOjkZWVhY++OADnDp1Ch4eHvD09Gxwm7GxsZg7dy4WLFgADw8PjBo1Cn/88QcAYPLkyUhNTUV0dDQ8PDxw9epVtcfW9Cni4U8JZWVliImJwZAhQzBw4EC8//77+PvvvwFUXhhl8ODB+PbbbzFgwAD4+vpiy5Ytwnb+/vtvLF++HP7+/nj22Wfx0ksvCY89deoUwsLC4OnpiZCQEKSmpjb4eRPVhSFPerFt2zaMHj0ao0ePxu+//46bN28CqLx6UHh4OJydnbFv3z4cOnQIQUFB6NSpE6KiouDu7o6MjAykp6c/Vrv79u3DqFGjkJ6ejoCAACxduhQA8P3338PT0xPvv/8+MjIyGnzul48//hhXr16FTCbDrl27UFhYiLi4OGH5zZs3ce/ePRw6dEg4S+OdO3cAVJ6A7OzZs9i4cSOOHz+Ot99+GxKJBAUFBQgPD8fMmTNx/PhxLFy4EHPmzKl23nsibTDkSefS09ORm5uLkSNHomfPnnB1dRVOFpaZmYnCwkIsWLAAVlZWaNas2WP12mvz7LPPws/PD+bm5ggNDcWFCxe03qZKpcLmzZuxePFi2NrawtraGuHh4UhMTBTWsbCwwJtvvglLS0v4+fnBysoKV69ehVKpxJYtW/DOO+8I57jv27cvpFIptm3bhsGDB8PPzw8SiQQ+Pj7o2bMnDh48qHXNRFU4u4Z0TiaTwcfHRzh5WXBwMBISEjBlyhTh9LMWFvr513v4lMfNmzdHaWkpKioqtGrv1q1bePDgAcaOHSvcp1Kp1K6EZWtrq9ZGixYtIJfLUVxcjNLSUri6ulbbbm5uLpKTk7F//37hvoqKCrWrRRFpiyFPOvX3339jx44dUCqV8PHxAVA5nn337l1cuHABTk5OyMvLqzF4zczMjFEygMpQrhonB4AbN24Iv7du3RrNmzdHYmJijad9rkvr1q3RrFkzZGdnVzvFspOTE0JDQ/Hhhx9qVzxRHThcQzpVdRWrxMREyGQyyGQyJCUlwdPTEzKZDL1794aDgwM++eQTyOVylJaW4sSJEwAqzwNfUFCg8ZRLXeratSsuXbqE8+fPo7S0FLGxscKyqmvofvTRRygqKgJQeY73lJSUercrkUjwwgsvYNmyZcKFTDIyMlBWVoaQkBDs378fKSkpUCgUKC0tRWpqKi+ZRzrFkCedSkhIwNixY+Hs7AwHBwfh55VXXsFvv/0GlUqF+Ph4XLt2Df7+/hg8eDB27NgBoPIc9Z07d4avr68wZBEfH4/XX39d73U//fTTePPNNzFlyhQMHz4czz77rNryt99+Gx06dMCLL76Ivn37YsqUKdVm6NRm4cKFeOaZZzBu3Dj069cPK1euhFKphJOTE9auXYsvv/wSAwYMgJ+fH7755hvRXBCdTAPPJ09EZMLYkyciMmEMeSIiE8aQJyIyYQx5IiITxpAnIjJhDHkiIhPGkCciMmEMeSIiE8aQJyIyYf8PwZoiPnk4LCgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "acctual_influence_1 = df0['0'].values\n",
    "acctual_influence_1 = acctual_influence_1[25:]\n",
    "predict_influence_1 = df0['1'].values\n",
    "predict_influence_1 = predict_influence_1[25:]\n",
    "low_limit = -np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.2\n",
    "up_limit = np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.2\n",
    "\n",
    "sns.set_theme()\n",
    "sns.set_style(\"dark\")\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "plt.axis('square')\n",
    "plt.xlabel('Act. Influence')\n",
    "plt.title('Reddit Node feature influence, Rho=0.376, pvalue=0.00011')\n",
    "plt.ylabel('Pred. Influence')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(low_limit, up_limit)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cab3eec4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a0f978ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-0.28544721626931274, 0.28544721626931274)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_edge_reddit = pd.read_csv('reddit_edge_influence.csv', header = None)\n",
    "df_edge_reddit\n",
    "acctual_influence_1 = df_edge_reddit[2].values\n",
    "# acctual_influence_1 = acctual_influence_1[25:]\n",
    "predict_influence_1 = df_edge_reddit[1].values\n",
    "# predict_influence_1 = predict_influence_1[25:]\n",
    "low_limit = -np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.2\n",
    "up_limit = np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))]) * 1.2\n",
    "\n",
    "sns.set_theme()\n",
    "sns.set_style(\"dark\")\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "plt.axis('square')\n",
    "plt.xlabel('Act. Influence')\n",
    "plt.title('Reddit Node feature influence, Rho=-0.015, pvalue=0.727')\n",
    "plt.ylabel('Pred. Influence')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(low_limit, up_limit)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "716376d4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([], dtype=int64),)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.where(acctual_influence_1 > 4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c6c1ef6f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "SpearmanrResult(correlation=-0.015224369687339095, pvalue=0.7270739102742363)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import scipy\n",
    "scipy.stats.spearmanr(acctual_influence_1, predict_influence_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8a04e17d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-0.015"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d63ebebc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy\n",
    "scipy.stats.spearmanr(acctual_influence_1, predict_influence_1)\n",
    "def plot_infl_reddit(df):\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",
    "    sns.set_theme()\n",
    "    sns.set_style(\"dark\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax.axis('square')\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax.set_ylim(low_limit, up_limit)\n",
    "    ax.set_xlim(low_limit, up_limit)\n",
    "#     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "186b0d2b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-20.0, 20.0)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# df1 = pd.read_csv('node_feature/cora_node_feature_influence.csv')\n",
    "# df2 = pd.read_csv('node_feature/pubmed_node_feature_influence.csv')\n",
    "# df3 = pd.read_csv('node_feature/citeseer_node_feature_influence.csv')\n",
    "\n",
    "df1 = pd.read_csv('node_feature_2/cora.csv')\n",
    "df2 = pd.read_csv('node_feature_2/pubmed.csv')\n",
    "df3 = pd.read_csv('node_feature_2/citeseer.csv')\n",
    "\n",
    "acctual_influence_1 = df1['actual influence'].values\n",
    "predict_influence_1 = df1['predicted influence'].values\n",
    "low_limit = -np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))])\n",
    "up_limit = np.max([np.max(np.abs(acctual_influence_1)), np.max(np.abs(predict_influence_1))])\n",
    "\n",
    "sns.set_theme(style=\"whitegrid\", font_scale=1)\n",
    "\n",
    "# sns.set(style=\"whitegrid\", font_scale=1.5)\n",
    "x = np.linspace(low_limit, up_limit)\n",
    "plt.plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "plt.scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "plt.ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "plt.axis('square')\n",
    "plt.xlabel('Act. Influence')\n",
    "plt.ylabel('Pred. Influence')\n",
    "plt.ylim(low_limit, up_limit)\n",
    "plt.xlim(-20, 20)\n",
    "# plt.xlim(low_limit, up_limit)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e4d19ec",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a0399282",
   "metadata": {},
   "outputs": [],
   "source": [
    "df4 = pd.read_csv('edge_feature/cora_edge_influence_001.csv', header = None)\n",
    "df5 = pd.read_csv('edge_feature/pubmed_edge_influence.csv', header = None)\n",
    "df6 = pd.read_csv('edge_feature/citeseer_edge_influence.csv', header = None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "310222e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "df7 = pd.read_csv('complete_node/cora.csv')\n",
    "df8 = pd.read_csv('complete_node/pubmed.csv')\n",
    "df9 = pd.read_csv('complete_node/citeseer.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "bb28bde0",
   "metadata": {},
   "outputs": [],
   "source": [
    "font_size = 12\n",
    "y_lab_xcoordinate = -0.25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "0fa6b7de",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_feature(df, ax, i, j, set_title_name = '', sep = 5, xlab_name = '', ylab_name = ''):\n",
    "    acctual_influence_1 = df['actual influence'].values\n",
    "    predict_influence_1 = df['predicted influence'].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",
    "    low_limit = -23.047763230628906\n",
    "    up_limit = 23.047763230628906\n",
    "\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"whitegrid\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    \n",
    "    ax[i, j].set_title(f'{set_title_name}', size = font_size)\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].set_xlim(low_limit, up_limit)\n",
    "#     ax[i, j].grid()\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, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    \n",
    "    ax[i, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    \n",
    "    ax[i, j].set_xticks([-20, -10, 0, 10, 20])\n",
    "    \n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "    ax[i, j].grid(which='both')\n",
    "\n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    \n",
    "#     ax.show()\n",
    "#     ax[i, j].legend(['line plot 1'], prop={'size': 6})\n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "24da50b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_edge(df, ax, i, j, plot_label = False, sep = 5, xlab_name = '', ylab_name = ''):\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 = -6.594854476955078\n",
    "    up_limit = 6.594854476955078\n",
    "\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"white\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    if plot_label:\n",
    "        ax[i, j].set_ylabel('Pred. Influence')\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].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, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i, j].set_xticks([-6, -3, 0, 3, 6])\n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "    ax[i, j].set_yticks([-6, -3, 0, 3, 6])\n",
    "\n",
    "    ax[i, j].grid(which='both')\n",
    "\n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    ax[i, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].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(a != 0)[0], np.where(b != 0)[0])\n",
    "    index_ = np.intersect1d(np.where(np.abs(a) > loss_threshold)[0], np.where(np.abs(b) > loss_threshold)[0])\n",
    "\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1[index_], predict_influence_1[index_])[0], 3)\n",
    "    \n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1[index_], predict_influence_1[index_])[0], 3)\n",
    "    \n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)\n",
    "    #     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "a089f13b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_node(df, ax, i, j, plot_label = False, sep = 5, xlab_name = '', ylab_name = ''):\n",
    "    acctual_influence_1 = df['acctual_influence'].values\n",
    "    predict_influence_1 = df['predict_influence'].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",
    "#     print(low_limit)\n",
    "#     print(up_limit)\n",
    "    low_limit = -12.487072592423942\n",
    "    up_limit = 12.487072592423942\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"dark\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    if plot_label:\n",
    "        \n",
    "        ax[i, j].set_xlabel('Actual Influence')\n",
    "#     ax[i, j].set_ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].set_xlim(low_limit, up_limit)\n",
    "#     ax.show()\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, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "    ax[i, j].grid(which='both')\n",
    "    \n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    ax[i, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "8924dffc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "average_threshold = 1e-5\n",
    "# loss_threshold = average_threshold * num_validate points\n",
    "loss_threshold = average_threshold * 1000\n",
    "sns.set_theme(style=\"whitegrid\", font_scale=1)\n",
    "\n",
    "figure, axis = plt.subplots(3, 3, figsize=(8, 8), constrained_layout=False)\n",
    "# figure, axis = plt.subplots(3, 3, figsize=(8, 8))\n",
    "figure.tight_layout(rect=[0, 0.03, 1, 0.95], h_pad = 1, w_pad = 2)\n",
    "##### For node features\n",
    "# cora\n",
    "plot_infl_feature(df1, axis, 0, 0, set_title_name='$\\it{Cora}$', \n",
    "                  xlab_name='Pred. Feat. Infl.', ylab_name = 'Act. Embed. Infl.')\n",
    "  \n",
    "# pubmed\n",
    "plot_infl_feature(df2, axis, 0, 1, set_title_name='$\\it{Pubmed}$', xlab_name='Pred. Embed. Infl.', \n",
    "                  ylab_name = 'Act. Feat. Infl.')\n",
    "\n",
    "# citeseer\n",
    "plot_infl_feature(df3, axis, 0, 2, set_title_name='$\\it{Citeseer}$', \n",
    "                  xlab_name='Pred. Feat. Infl.', ylab_name = 'Act. Embed. Infl.')\n",
    "  \n",
    "    \n",
    "# For edges\n",
    "\n",
    "#cora\n",
    "# plot_infl_edge(df4, axis, 1, 0, plot_label=True)\n",
    "plot_infl_edge(df4, axis, 1, 0, plot_label=False, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.')\n",
    "# pubmed\n",
    "plot_infl_edge(df5, axis, 1, 1, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.')\n",
    "\n",
    "# citeseer\n",
    "plot_infl_edge(df6, axis, 1, 2, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.')\n",
    "\n",
    "# For nodes\n",
    "plot_infl_node(df7, axis, 2, 0, xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.')\n",
    "\n",
    "# plot_infl_node(df8, axis, 2, 1, plot_label=True)\n",
    "plot_infl_node(df8, axis, 2, 1, plot_label=False, xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.')\n",
    "plot_infl_node(df9, axis, 2, 2,  xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.')\n",
    "\n",
    "# Combine all the operations and display\n",
    "# figure.supxlabel(\"Actual Influence\")\n",
    "# figure.supylabel(\"Predicted Influence\")\n",
    "# plt.subplots_adjust(\n",
    "#                     wspace=0.5, \n",
    "#                     hspace=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "26840cdb",
   "metadata": {},
   "outputs": [],
   "source": [
    "figure.savefig('final_experiment0_small_33.png', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "638e4508",
   "metadata": {},
   "outputs": [],
   "source": [
    "figure.savefig('experiment0_small_v7.pdf', dpi = 440)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "92384481",
   "metadata": {},
   "outputs": [],
   "source": [
    "figure.savefig('small_dataset_influence_high_resolution.png', bbox_inches='tight', dpi = 660)\n",
    "figure.savefig('small_dataset_influence_low_resolution.png', bbox_inches='tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "id": "073dbc6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_feature_medium(df, ax, i, j, set_title_name = '', sep = 5, xlab_name = '', ylab_name = '', \n",
    "                             low_limit = -23.047763230628906, up_limit = 23.047763230628906, xticks = [-20, -10, 0, 10, 20]\n",
    "):\n",
    "    acctual_influence_1 = df['actual influence'].values\n",
    "    predict_influence_1 = df['predicted influence'].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",
    "    low_limit = low_limit\n",
    "    up_limit = up_limit\n",
    "\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"whitegrid\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    \n",
    "    ax[i, j].set_title(f'{set_title_name}', size = font_size)\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].set_xlim(low_limit, up_limit)\n",
    "#     ax[i, j].grid()\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, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    \n",
    "    ax[i, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    \n",
    "    ax[i, j].set_xticks(xticks)\n",
    "    \n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "    ax[i, j].grid(which='both')\n",
    "\n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    \n",
    "#     ax.show()\n",
    "#     ax[i, j].legend(['line plot 1'], prop={'size': 6})\n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 205,
   "id": "bace27f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_edge_medium(df, ax, i, j, plot_label = False, sep = 5, xlab_name = '', ylab_name = '', \n",
    "                  low_limit = -6.594854476955078, up_limit = 6.594854476955078, xticks = [-6, -3, 0, 3, 6]):\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",
    "\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"white\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    if plot_label:\n",
    "        ax[i, j].set_ylabel('Pred. Influence')\n",
    "#     ax.xlabel('Act. Influence')\n",
    "#     ax.ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].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, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i, j].set_xticks(xticks)\n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "#     ax[i, j].set_yticks([-6, -3, 0, 3, 6])\n",
    "\n",
    "    ax[i, j].grid(which='both')\n",
    "\n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    ax[i, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    \n",
    "    a = np.array(acctual_influence_1)\n",
    "#     a = np.around(a, 16)\n",
    "    b = np.array(predict_influence_1)\n",
    "#     b = np.around(b, 16)\n",
    "#     index_ = np.intersect1d(np.where(a != 0)[0], np.where(b != 0)[0])\n",
    "    index_ = np.intersect1d(np.where(np.abs(a) > loss_threshold)[0], np.where(np.abs(b) > loss_threshold)[0])\n",
    "    \n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1[index_], predict_influence_1[index_])[0], 3)\n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)\n",
    "    #     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "id": "30b8a7a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_node_medium(df, ax, i, j, plot_label = False, sep = 5, xlab_name = '', ylab_name = '', \n",
    "                  low_limit = -12.487072592423942, up_limit = 12.487072592423942, xticks = []):\n",
    "    acctual_influence_1 = df['acctual_influence'].values\n",
    "    predict_influence_1 = df['predict_influence'].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",
    "#     print(low_limit)\n",
    "#     print(up_limit)\n",
    "    low_limit = low_limit\n",
    "    up_limit = up_limit\n",
    "    sns.set_theme()\n",
    "    sns.set_style(\"dark\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i, j].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i, j].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i, j].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i, j].axis('square')\n",
    "    if plot_label:\n",
    "        \n",
    "        ax[i, j].set_xlabel('Actual Influence')\n",
    "#     ax[i, j].set_ylabel('Pred. Influence')\n",
    "    ax[i, j].set_ylim(low_limit, up_limit)\n",
    "    ax[i, j].set_xlim(low_limit, up_limit)\n",
    "#     ax.show()\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, j].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i, j].set_yticks(grid_y_ticks , minor=True)\n",
    "    ax[i, j].set_xticks(xticks)\n",
    "    ax[i, j].set_yticks(xticks)\n",
    "    ax[i, j].grid(which='both')\n",
    "    \n",
    "    ax[i, j].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    ax[i, j].set_xlabel(xlab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].set_ylabel(ylab_name, loc=\"center\", size = font_size)\n",
    "    ax[i, j].yaxis.set_label_coords(x = y_lab_xcoordinate, y = 0.5)\n",
    "    corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    ax[i, j].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "4d90ec29",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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yz5LJBKUlJTAyclJreNtbGxQUVEht620tBS2trZKy1taWmLTpk04d+4c+vfvj6ioKERGRspVewK1s2QHBQUhNzcXe/fuldsnkUjw4YcfwtLSEsuWLVMrT3OCDJDh0Fb/1tbWKC0tldvWkP4lEgmmTp2K8PBw3L59G1evXsWLFy/w5Zdf1isbExODwMBAtGnTRmlcVfeHOUMG6B8WLlyIESNGYOXKlSguLtb5+U1J+9LankmTJsHFxQWOjo549913ce7cObWOZwvGMEAAx03QnTt30LJlS9nnq1evwsHBAR06dMC0adMQEBCg9GfatGkAgPbt20MsFiM9PV12jqSkJJVNVL6+vti1axeuXbuGbdu2ITMzE927d1daViwWy/V5YBgGS5YswdOnT7Fx40bWGQQyQIZFW/27ubmprf/nz58jJycHEydOhFAohIODA15//XWcP3++XtlDhw5h1KhRjeaveH+YM2SA/mH37t34/fff8euvv4JhGKxevVrnMUxJ+y1atICbm1uDX/qlpaVq3zvmirEMEMDh5rDq6mo8fvwYJ06cQEREBJ48eYJVq1Zh4cKFAIAff/yx0XPY2NggODgY33zzDdauXYvExET88ccf2LdvX4PHJCUlwcvLCxKJBHv27EF+fj5ee+01FBYW4urVqxg0aBCsra1x+fJlHDlyBF999ZXs2BUrVuDRo0eIioqSvT2wBTJAhkUX+re2tkZ4eLha+nd0dISnpyf27t2LKVOmoLy8HNHR0ejcubNcuT///BN5eXlyo8IAqHV/mCtkgOSRrg4gFAoxYcIEzJo1S6fnN0Xtv/baa9i5cycGDBgACwsL7NixA4MGDQIANG/eXK17x1wxpgECOGyCHj16hNatW6NTp07o27cvnJycMGvWrHoP38aYMmUK9u/fj759+6Jly5ZYuXKl3BDJadOmISgoCDNnzgRQ+5b7yy+/oKamBoGBgYiKioJQKASPx8PevXuxYsUKSCQStG7dGosXL5a1+xYUFGD//v0QCoXo37+/7PyrVq3Cq6++qoO/iPFgy1IY5oSu9L9ixQosXrxYLf1/++23+PTTT7F161bw+Xz07t0bixcvljtfTEwMwsPD6xmBxu4Pc4UMkDzl5eUQi8Wwt7cHwzA4evQo/Pz8dBrDFLU/e/ZsPHv2DBEREbCyssLQoUPlzJ869445YmwDBABg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\n",
      "text/plain": [
       "<Figure size 576x576 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "average_threshold = 1e-5\n",
    "# loss_threshold = average_threshold * num_validate points\n",
    "loss_threshold = cultimate_threshold * 1000\n",
    "df10 = pd.read_csv('wikics_influence/node_feature_influence.csv')\n",
    "df11 = pd.read_csv('amazon_dataset/computer_node_feature_influence.csv')\n",
    "df12 = pd.read_csv('amazon_dataset/photo_node_feature_influence.csv')\n",
    "df13 = pd.read_csv('wikics_influence/edge_influence.csv', header = None)\n",
    "df14_1 = pd.read_csv('amazon_dataset/computer_edges/computer_edge_influence_q1.csv', header = None)\n",
    "df14_2 = pd.read_csv('amazon_dataset/computer_edges/computer_edge_influence_q2.csv', header = None)\n",
    "df14_3 = pd.read_csv('amazon_dataset/computer_edges/computer_edge_influence_q3.csv', header = None)\n",
    "df14_4 = pd.read_csv('amazon_dataset/computer_edges/computer_edge_influence_q4.csv', header = None)\n",
    "df14 = pd.concat([df14_1, df14_2, df14_3, df14_4])\n",
    "\n",
    "df15_1 = pd.read_csv('amazon_dataset/photo_edges/photo_edge_influence_q1.csv', header = None)\n",
    "df15_2 = pd.read_csv('amazon_dataset/photo_edges/photo_edge_influence_q2.csv', header = None)\n",
    "df15_3 = pd.read_csv('amazon_dataset/photo_edges/photo_edge_influence_q3.csv', header = None)\n",
    "df15_4 = pd.read_csv('amazon_dataset/photo_edges/photo_edge_influence_q4.csv', header = None)\n",
    "df15 = pd.concat([df15_1, df15_2, df15_3, df15_4])\n",
    "df16 = pd.read_csv('wikics_influence/complete_node_influence.csv')\n",
    "df17 = pd.read_csv('amazon_dataset/computer_complete_node_influence.csv')\n",
    "df18 = pd.read_csv('amazon_dataset/photo_complete_node_influence.csv')\n",
    "sns.set_theme(style=\"whitegrid\", font_scale=1)\n",
    "\n",
    "\n",
    "figure, axis = plt.subplots(3, 3, figsize=(8, 8), constrained_layout=False)\n",
    "# figure, axis = plt.subplots(3, 3, figsize=(8, 8))\n",
    "figure.tight_layout(rect=[0, 0.03, 1, 0.95], h_pad = 1, w_pad = 2)\n",
    "# For node features\n",
    "# cora\n",
    "plot_infl_feature_medium(df10, axis, 0, 0, set_title_name='$\\it{WikiCS}$', \n",
    "                  xlab_name='Pred. Feat. Infl.', ylab_name = 'Act. Feat. Infl.')\n",
    "  \n",
    "# pubmed\n",
    "plot_infl_feature_medium(df11, axis, 0, 1, set_title_name='$\\it{AmazonComputer}$', xlab_name='Pred. Feat. Infl.', \n",
    "                  ylab_name = 'Act. Feat. Infl.', low_limit=-11, up_limit=11, xticks=[-10, -5, 0, 5, 10])\n",
    "\n",
    "# citeseer\n",
    "plot_infl_feature_medium(df12, axis, 0, 2, set_title_name='$\\it{AmazonPhoto}$', \n",
    "                  xlab_name='Pred. Feat. Infl.', ylab_name = 'Act. Feat. Infl.', \n",
    "                        low_limit=-7, up_limit=7, xticks=[-6, -3, 0, 3, 6])\n",
    "  \n",
    "    \n",
    "# For edges\n",
    "\n",
    "#cora\n",
    "# plot_infl_edge(df4, axis, 1, 0, plot_label=True)\n",
    "plot_infl_edge_medium(df13, axis, 1, 0, plot_label=False, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.',\n",
    "                     low_limit = -1.1, up_limit = 1.1, xticks = [-1, -0.5, 0, 0.5, 1])\n",
    "# pubmed\n",
    "plot_infl_edge_medium(df14, axis, 1, 1, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.', \n",
    "                     low_limit = -1.1, up_limit = 1.1, xticks = [-1, -0.5, 0, 0.5, 1])\n",
    "\n",
    "# citeseer\n",
    "plot_infl_edge_medium(df15, axis, 1, 2, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.',\n",
    "                     low_limit = -1.1, up_limit = 1.1, xticks = [-1, -0.5, 0, 0.5, 1])\n",
    "\n",
    "# For nodes\n",
    "plot_infl_node_medium(df16, axis, 2, 0, xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.',\n",
    "                     low_limit=-7, up_limit=7, xticks=[-6, -3, 0, 3, 6])\n",
    "\n",
    "# plot_infl_node(df8, axis, 2, 1, plot_label=True)\n",
    "plot_infl_node_medium(df17, axis, 2, 1, plot_label=False, xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.',\n",
    "                low_limit=-7, up_limit=7, xticks=[-6, -3, 0, 3, 6])\n",
    "plot_infl_node_medium(df18, axis, 2, 2,  xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.', \n",
    "                     low_limit=-7, up_limit=7, xticks=[-6, -3, 0, 3, 6])\n",
    "\n",
    "# Combine all the operations and display\n",
    "# figure.supxlabel(\"Actual Influence\")\n",
    "# figure.supylabel(\"Predicted Influence\")\n",
    "# plt.subplots_adjust(\n",
    "#                     wspace=0.5, \n",
    "#                     hspace=0.5)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "ae54f879",
   "metadata": {},
   "outputs": [],
   "source": [
    "figure.savefig('large_dataset_influence_high_resolution.png', bbox_inches='tight', dpi = 660)\n",
    "figure.savefig('large_dataset_influence_low_resolution.png', bbox_inches='tight', dpi = 300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43c4cd5a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "724b2553",
   "metadata": {},
   "outputs": [],
   "source": [
    "df10 = pd.read_csv('wikics_influence/node_feature_influence.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "3f60b03c",
   "metadata": {},
   "outputs": [],
   "source": [
    "df11 = pd.read_csv('wikics_influence/edge_influence.csv', header = None)\n",
    "df12 = pd.read_csv('wikics_influence/complete_node_influence.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "61dc787b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_feature_large_data(df, ax, i, set_title_name = '', sep = 5, xlab_name = '', ylab_name = ''):\n",
    "    acctual_influence_1 = df['actual influence'].values\n",
    "    predict_influence_1 = df['predicted influence'].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",
    "    sns.set_theme()\n",
    "    sns.set_style(\"whitegrid\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i].axis('square')\n",
    "    \n",
    "    ax[i].set_title(f'{set_title_name}')\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",
    "#     ax[i].grid()\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_xlabel(xlab_name, loc=\"center\", size = 12)\n",
    "    ax[i].set_ylabel(ylab_name, loc=\"center\", size = 12)\n",
    "    ax[i].yaxis.set_label_coords(x = -0.195, y = 0.5)\n",
    "    \n",
    "    ax[i].set_xticks(grid_x_ticks , minor=True)\n",
    "    ax[i].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "    ax[i].grid(which='both')\n",
    "\n",
    "    ax[i].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "#     corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "    corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    \n",
    "#     ax.show()\n",
    "#     ax[i].legend(['line plot 1'], prop={'size': 6})\n",
    "    ax[i].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "id": "5b5c1c5c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_edge_large_data(df, ax, i, plot_label = False, sep = 5, xlab_name = '', ylab_name = '', \n",
    "                             set_title_name = '', rounding = 3):\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",
    "    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",
    "    ax[i].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\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_yticks(grid_y_ticks , minor=True)\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 = 12)\n",
    "    ax[i].set_ylabel(ylab_name, loc=\"center\", size = 12)\n",
    "    ax[i].yaxis.set_label_coords(x = -0.195, y = 0.5)\n",
    "    ax[i].set_title(f'{set_title_name}', fontsize = 15)\n",
    "    if rounding:\n",
    "        a = np.array(acctual_influence_1)\n",
    "        a = np.around(a, rounding)\n",
    "        b = np.array(predict_influence_1)\n",
    "        b = np.around(b, rounding)\n",
    "    index_ = np.intersect1d(np.where(a != 0)[0], np.where(b != 0)[0])\n",
    "    \n",
    "    corr = np.round(scipy.stats.pearsonr(acctual_influence_1[index_], predict_influence_1[index_])[0], 3)\n",
    "    ax[i].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)\n",
    "    #     ax.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "id": "097fb353",
   "metadata": {},
   "outputs": [],
   "source": [
    "# def plot_infl_node_large_data(df, ax, i, plot_label = False, sep = 5, xlab_name = '', ylab_name = ''):\n",
    "#     acctual_influence_1 = df['acctual_influence'].values\n",
    "#     predict_influence_1 = df['predict_influence'].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",
    "#     sns.set_theme()\n",
    "#     sns.set_style(\"dark\")\n",
    "#     x = np.linspace(low_limit, up_limit)\n",
    "#     ax[i].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "#     ax[i].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "#     ax[i].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "#     ax[i].axis('square')\n",
    "#     if plot_label:\n",
    "        \n",
    "#         ax[i].set_xlabel('Actual Influence')\n",
    "# #     ax[i].set_ylabel('Pred. Influence')\n",
    "#     ax[i].set_ylim(low_limit, up_limit)\n",
    "#     ax[i].set_xlim(low_limit, up_limit)\n",
    "# #     ax.show()\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_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "#     ax[i].set_aspect('equal', adjustable='box')\n",
    "\n",
    "    \n",
    "#     print(grid_x_ticks, grid_y_ticks)\n",
    "    \n",
    "#     ax[i].grid(which='both')\n",
    "    \n",
    "#     ax[i].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    \n",
    "#     ax[i].set_xlabel(xlab_name, loc=\"center\", size = 12)\n",
    "#     ax[i].set_ylabel(ylab_name, loc=\"center\", size = 12)\n",
    "# #     ax[i].yaxis.set_label_coords(x = -0.195, y = 0.5)\n",
    "# #     corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "#     corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "#     ax[i].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "7af14d3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_infl_node_large_data(df, ax, i, plot_label = False, sep = 5, xlab_name = '', ylab_name = ''):\n",
    "    acctual_influence_1 = df['acctual_influence'].values\n",
    "    predict_influence_1 = df['predict_influence'].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",
    "    sns.set_theme()\n",
    "    sns.set_style(\"dark\")\n",
    "    x = np.linspace(low_limit, up_limit)\n",
    "    ax[i].plot(x, x, color=\"grey\", alpha=0.25, zorder=0)\n",
    "    ax[i].scatter(acctual_influence_1, predict_influence_1, s = 20, label = 'A', linewidths=0)\n",
    "    ax[i].ticklabel_format(style=\"sci\", scilimits=(-4, 4))\n",
    "    ax[i].axis('square')\n",
    "    if plot_label:\n",
    "        \n",
    "        ax[i].set_xlabel('Actual Influence')\n",
    "#     ax[i].set_ylabel('Pred. Influence')\n",
    "    ax[i].set_ylim(low_limit, up_limit)\n",
    "    ax[i].set_xlim(low_limit, up_limit)\n",
    "#     ax.show()\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([-20, -10, 0, 10, 20])\n",
    "    ax[i].set_yticks(grid_y_ticks , minor=True)\n",
    "\n",
    "    ax[i].set_aspect('equal', adjustable='box')\n",
    "\n",
    "    print(grid_x_ticks, grid_y_ticks)\n",
    "    \n",
    "    ax[i].grid(which='both')\n",
    "    \n",
    "    ax[i].grid(which='minor', alpha=1, linestyle='-')\n",
    "    \n",
    "    \n",
    "    ax[i].set_xlabel(xlab_name, loc=\"center\", size = 12)\n",
    "    ax[i].set_ylabel(ylab_name, loc=\"center\", size = 12)\n",
    "#     ax[i].yaxis.set_label_coords(x = -0.195, y = 0.5)\n",
    "#     corr = np.round(scipy.stats.spearmanr(acctual_influence_1, predict_influence_1).correlation, 3)\n",
    "    corr = np.round(scipy.stats.pearsonr(acctual_influence_1, predict_influence_1)[0], 3)\n",
    "    ax[i].text(low_limit * (7/8), up_limit * (2 /3), str('$\\u03C1$=') + str(corr), fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "d79ac1b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-22.75792528 -13.65475517  -4.55158506   4.55158506  13.65475517] [-22.75792528 -13.65475517  -4.55158506   4.55158506  13.65475517]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 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=(8, 8))\n",
    "plt.tight_layout(w_pad = 2.1)\n",
    "plot_infl_feature_large_data(df10, axis, 0, set_title_name='', \n",
    "                  xlab_name='Pred. Feat. Infl.', ylab_name = 'Act. Feat. Infl.')\n",
    "\n",
    "plot_infl_edge_large_data(df11, axis, 1, plot_label=False, xlab_name='Pred. Edge Infl.', ylab_name = 'Act. Edge Infl.', \n",
    "                         set_title_name='Influence of elements on WikiCS dataset')\n",
    "\n",
    "plot_infl_node_large_data(df12, axis, 2, xlab_name='Pred. Node Infl.', ylab_name = 'Act. Node Infl.')\n",
    "# figure.supxlabel(\"Actual Influence\")\n",
    "# figure.supylabel(\"Predicted Influence\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2ef2b17d",
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-0.038169</td>\n",
       "      <td>-0.000013</td>\n",
       "      <td>4603.0</td>\n",
       "      <td>11080.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-0.048502</td>\n",
       "      <td>0.001679</td>\n",
       "      <td>993.0</td>\n",
       "      <td>8262.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-0.020953</td>\n",
       "      <td>0.000662</td>\n",
       "      <td>11343.0</td>\n",
       "      <td>7700.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-0.018014</td>\n",
       "      <td>0.000144</td>\n",
       "      <td>10083.0</td>\n",
       "      <td>7267.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.007308</td>\n",
       "      <td>-0.000016</td>\n",
       "      <td>9299.0</td>\n",
       "      <td>6919.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>-0.021258</td>\n",
       "      <td>0.000120</td>\n",
       "      <td>10097.0</td>\n",
       "      <td>438.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>-0.021490</td>\n",
       "      <td>0.000011</td>\n",
       "      <td>11345.0</td>\n",
       "      <td>7264.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>-0.030067</td>\n",
       "      <td>-0.001380</td>\n",
       "      <td>8300.0</td>\n",
       "      <td>5011.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>-0.028123</td>\n",
       "      <td>-0.000104</td>\n",
       "      <td>4139.0</td>\n",
       "      <td>11282.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>-0.009536</td>\n",
       "      <td>0.000847</td>\n",
       "      <td>1933.0</td>\n",
       "      <td>10051.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "             0         1        2        3\n",
       "0    -0.038169 -0.000013   4603.0  11080.0\n",
       "1    -0.048502  0.001679    993.0   8262.0\n",
       "2    -0.020953  0.000662  11343.0   7700.0\n",
       "3    -0.018014  0.000144  10083.0   7267.0\n",
       "4     0.007308 -0.000016   9299.0   6919.0\n",
       "...        ...       ...      ...      ...\n",
       "9995 -0.021258  0.000120  10097.0    438.0\n",
       "9996 -0.021490  0.000011  11345.0   7264.0\n",
       "9997 -0.030067 -0.001380   8300.0   5011.0\n",
       "9998 -0.028123 -0.000104   4139.0  11282.0\n",
       "9999 -0.009536  0.000847   1933.0  10051.0\n",
       "\n",
       "[10000 rows x 4 columns]"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83f2ee39",
   "metadata": {},
   "outputs": [],
   "source": [
    "import cv2\n",
    "from matplotlib import pyplot as plt\n",
    "sns.set_theme(style=\"whitegrid\", font_scale=1)\n",
    "\n",
    "# create figure\n",
    "fig = plt.figure(figsize=(36, 12))\n",
    "  \n",
    "# setting values to rows and column variables\n",
    "rows = 1\n",
    "columns = 3\n",
    "  \n",
    "# reading images\n",
    "Image1 = cv2.imread('task2/rev_cora_adversarial_attack_v4.png')\n",
    "Image2 = cv2.imread('task2/rev_pubmed_adversarial_attack_v2.png')\n",
    "Image3 = cv2.imread('task2/rev_citeseer_adversarial_attack_v1.png')\n",
    "  \n",
    "# Adds a subplot at the 1st position\n",
    "fig.add_subplot(rows, columns, 1)\n",
    "  \n",
    "# showing image\n",
    "plt.imshow(Image1)\n",
    "plt.axis('off')\n",
    "\n",
    "  \n",
    "# Adds a subplot at the 2nd position\n",
    "fig.add_subplot(rows, columns, 2)\n",
    "  \n",
    "# showing image\n",
    "plt.imshow(Image2)\n",
    "plt.axis('off')\n",
    "\n",
    "  \n",
    "# Adds a subplot at the 3rd position\n",
    "fig.add_subplot(rows, columns, 3)\n",
    "  \n",
    "# showing image\n",
    "plt.imshow(Image3)\n",
    "plt.axis('off')\n",
    "plt.tight_layout()\n",
    "  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6eca5415",
   "metadata": {},
   "outputs": [],
   "source": [
    "foo = \"some fancy label and $\\u03C1$\"\n",
    "plt.plot(1,1, label = foo)\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2833101b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
