{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "from embedding_functions import *\n",
    "from experiment_setup import *\n",
    "from functions_for_bootstrap import *\n",
    "import numba as nb\n",
    "from scipy.stats import wasserstein_distance\n",
    "from tqdm import tqdm\n",
    "import random"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Use the test with $M$ samples drawn from the same distribution - compared to one bootstrap from itself each time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Network generation --------------------------------------------------------\n",
    "random.seed(10)\n",
    "np.random.seed(10)\n",
    "\n",
    "n = 1000  # number of nodes\n",
    "K = 4   # number of node communities\n",
    "\n",
    "# Community labels\n",
    "tau = np.random.choice(K, n) # order tau would make the nice blocks\n",
    "tau = np.sort(tau)\n",
    "# print(tau)\n",
    "\n",
    "# Generate stochastic block model (SBM) B matrix\n",
    "\"\"\"Just one observation is required\"\"\"\n",
    "B_list = []\n",
    "\n",
    "B_symm = np.array([[0.7, 0.4, 0.2, 0.5],\n",
    "                   [0.4, 0.6, 0.3, 0.2],\n",
    "                   [0.2, 0.3, 0.7, 0.4],\n",
    "                   [0.5, 0.2, 0.4, 0.9]])\n",
    "\n",
    "B_list.append(B_symm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generate adjacency matrix from the B matrix\n",
    "As = np.zeros((n, n))\n",
    "P_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "# Get probability matrix from B\n",
    "P_t = np.column_stack(\n",
    "    [B_list[0][tau, tau[i]] for i in range(n)])\n",
    "P_list.append(P_t)\n",
    "\n",
    "# Generate random graph from the P matrix\n",
    "A_t = np.random.binomial(n=1, p=P_t)\n",
    "# turn to integer from float\n",
    "A_t = A_t.astype(int)\n",
    "As = A_t\n",
    "\n",
    "As = As.astype(int)\n",
    "P = np.column_stack(P_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\" Generate more samples from the same model with the same parameters (P matrix)\"\"\"\n",
    "\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "M=200\n",
    "A_true_draws = []\n",
    "\n",
    "for m in range(M):\n",
    "    # Generate random graph from the P matrix\n",
    "    A_t = np.random.binomial(n=1, p=P_t)\n",
    "    # turn to integer from float\n",
    "    A_t = A_t.astype(float)\n",
    "    As = A_t\n",
    "\n",
    "    As = As.astype(float)\n",
    "\n",
    "    # make symmetric by setting the lower triangle equal to the upper triangle\n",
    "    As = np.triu(As) + np.triu(As).T - np.diag(As.diagonal())\n",
    "\n",
    "    A_true_draws.append(As)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=4"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-kNN k=5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "k=5\n",
    "\n",
    "p_vals_k5 = []\n",
    "A_boots_list_k5 = []\n",
    "\n",
    "for m in A_true_draws:\n",
    "    p_val, A_boots = create_single_kNN_bootstrap(m, d=d, Q=1000, n_neighbors=k)\n",
    "    p_vals_k5.append(p_val)\n",
    "    A_boots_list_k5.append(A_boots)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQYAAAD8CAYAAACVSwr3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnbklEQVR4nO3deViVdf7/8ecbEBQxFRcUzQUVBbc0mjI1zdzCNLe0zNJmyklz2hytpn7a3liNjpnmMl6atkyZ1VSK4KSpowcR0hzcYsQlUQkzl1JE4PP74xz6InDgAGfj8H5cl5dx35/7nFcKL+/7c9/nvsUYg1JKFebn6QBKKe+jxaCUKkaLQSlVjBaDUqoYLQalVDEBng5QVMOGDU2rVq08HUMpn5aSknLaGNPI3nqvK4ZWrVqRnJzs6RhK+TQROVraej2UUEoVo8WglCpGi0EpVYwWg1KqGC0GpVQxDhWDiNwiIl+ISIaIGBGZ6MA2nUVks4hcsm03U0Sk0omVUi7n6B5DCJAKPAZcKmuwiFwDbAAygRts200HnqxYTKWUOzl0HYMxZh2wDkBEVjiwyb1AMDDBGHMJSBWRDsCTIjLH6Ge9lXKqy7mX+eDbD2jRoAW3tbmt0q/nqjmGHsBWWykUiAfCgVZFB4vIJBFJFpHkrKwsF0VSyjd9sf8Lbll0Cy9veZnP93zulNd0VTE0wXoYUVhmoXVXMcYsMcbEGGNiGjWye5WmUqqIXSd2MW3dNJrWbcrTHZ9m7tC5Tnldr7skWinlmOwr2Tz2+WM0rt2YVWNWUSeojtNe21V7DKeAsCLLwgqtU0pV0vTV08m4mMHdYXc7tRTAdcVgAXqLSM1CywYAJ4AjLnpPpaqNf236F3EZcdwQcgNThk1x+us7eh1DiIhcJyLX2bZpYfu6hW39ayLydaFNPgAuAitEpJOIjASeBvSMhFKVZLFYWJi4EH/xZ849c/D393f6ezi6xxAD7LL9qgW8YPvvF23rmwJtCgYbY85h3UMIB5KBBcDfgDlOSa1UNXXlyhW+3vk16TXSGXfdOMLrhrvkfRy9juEbwO5Vi8aYiSUs+y9wS0WDKaWuZowhICCAzJaZ1EivweSbJrvsvfSshFJVgMViISMjg0ONDrEubR1TbppC45DGLns/LQalvJzFYiEhIYEfmv7ApiObGNd1HE/0fMKl76mfrlTKixWUQo3WNdh0fhNjOo/hxf4v4ieu/dHVYlDKS+3YsYOEhAQiOkSw7tI6IkIjmNVvFu74kLIeSijlpZo0aULXrl2x1LSQeTyT1eNWU7NGzbI3dALdY1DKy5w6Zb04uGXLltTtUpdPUj9h0g2TuK7pdW7LoMWglBdJTExk8eLFpKWlcS77HM8mPEu7Bu149OZH3ZpDDyWU8hKJiYnEx8cTHR1NREQEM+JncPrX0ywevpiggCC3ZtE9BqW8QOFSGDlyJBsPb+TzfZ8z+cbJdG7S2e15tBiU8rCTJ09eVQrnc87zXMJzRDWK4pEej3gkkx5KKOVhTZs25Z577qFNmzYg8GzCs5zNPsuK0SsI9A/0SCbdY1DKQ5KSkjh27BgAkZGRIDBj/Qzi0+KZccsMohpHeSybFoNSHpCYmEhcXBy7du0CIDc/l2nrpvH5vs+Z1msaf4j5g0fz6aGEUm5WeKLxjjvuIDc/lyfXPsnag2uZ3ns6D9/4sKcjajEo5U5Fzz74+fnx57g/s/bgWp665Skm/W6SpyMCeiihlNsYYzh+/PhvpeDv78+XB77k832f82iPR72mFED3GJRyiytXrlCjRg1GjhyJMQZ/f39+/OVHnv/6ebo17cbUHlM9HfEqWgxKuZjFYuHbb7/lgQceICAogBc3vsh3J7/jzMUzZOdm8/rtr+Pv5/z7NlaGFoNSLlRwP4Xo6GjEX5j6xVS+PvQ1vVv1JrxOOKM6jSIiNMLTMYvRYlDKRQqXQkSPCB747AF2Ht/JC7e9wPhu4z0dr1RaDEq5wO7du0lISCA4IpgvzZds++c2QmuF8vrg1xnVaZSn45VJi0EpFzhf+zxJYUkcyDxAaK1QnrrlKe697l5qB9b2dDSHaDEo5USrt63msx8+Y8fxHTQMbsgzfZ5hXNdxBAcGezpauWgxKOUE2VeyuW/VfXx75lvq1ajHc7c+x91d7qZWjVqejlYhWgxKVdKlK5cYu2Ise8/u5fb6tzP7vtnUDqoahwz26JWPSlWQMYbNhzdzxz/uYO/ZvYxpOIZ5D8yr8qUAusegVIU99tVjrD24lhATwvjG45k5fqZLHjDrCVoMSlXAzuM7WXtwLQ/GPMiEDhMIaxTmM6UA5TiUEJEpInJYRLJFJEVEepcxfpyI7BaRiyJySkTeE5EmlY+slOe9GPcidWvU5fGejxPeJNynSgEcLAYRGQvMA14FugHbgTgRaWFnfE9gFfAu0BEYDkQD71c+slKetWz9Mvad20fvkN7UDHDPA2DczdE9hieBFcaYpcaY/caYPwEnAXvP4e4BHDfGzDXGHDbGJALzgRsrH1kpz9m2fRtLv1tKHf86vDr+Vbc8Ls4TyiwGEQkErgcSiqxKAG62s9k2oKmIDBWrhsDdwLrKhFXKkxITE3lr01tk+WfxXP/nfOLsgz2O7DE0BPyBzCLLM4ES5wyMMRasRfA+kANkAQJMKGm8iEwSkWQRSc7KynIwulLulXk5k901d9Mvol+V+LxDZbjkOgYRicZ66PAS1r2NwVhLZHFJ440xS4wxMcaYmEaNGrkiklIVdv78ec5eOss/jv6D2kG1eWXgKz57CFHAkdOVp4E8IKzI8jDglJ1tngGSjDFv2L7eIyK/AltF5C/GmOMVSquUm1ksFuI2xbEzbCdHzh/hnTvfoXFIY0/Hcrky9xiMMTlACjCgyKoBWM9OlCQYa5kUVvC1Xm2pqgSLxcL6hPVsCdnCkfNHWDR8EX0j+no6lls4eoHTHGCViCRhnVh8GAgHFgGIyEoAY8z9tvFfAktFZDIQDzQF/g58a4w55rT0SrlIwU1WssKz+OHcD8wdMpc+rft4OpbbOFQMxpiPRKQB8BzWH/JUINYYc9Q2pEWR8StEpA4wFfgbcA7YCDzlrOBKuUpaWhoJCQnUb1OfD3/8kNjIWIZFDfN0LLcSY4ynM1wlJibGJCcnezqGqsby8/NJTk5mbvpcDp05xPqJ6wkNDvV0LKcSkRRjTIy99Xq8r5TNrl27OH/+PH5+fjTv0Jyk40lM7D7R50rBEVoMSmGdU/jiiy/Yvt06nx73fRwAse1jPRnLY7QYVLVXMNEYFRXFgAHWk2/rDq6jY1hHWtVv5dlwHqLFoKq1wqUwatQo/P39OX7uOLtP7mZI5BBPx/MYLQZVbeXm5vLdd99dVQqghxGgN2pR1ZQxhoCAACZMmEBgYCD+/v5cuHyBFSkrWJayjC5NunBtvWs9HdNjtBhUtWOxWDh69Ch33XUXtWpZ7+Kcb/IZ//F4UjNT6d+2P0/f8rSHU3qWFoOqVgo/Nq6w+O/jSc1MZfbg2YzuNNpD6byHzjGoaqNwKYwcOfK3OYV8k8+87fNoG9qWEdEjPJzSO2gxqGohKSmpxFIA66nJtJ/SmHrzVK97HL2n6KGEqhaaN29Ot27dGDJkCBdyLpBxPoM8k8dXB77ig90f0K5BO2Ijq+9ZiKK0GJRPy8jIoFmzZoSHh3PzbTfz1y1/5YPvPiA7NxsAP/FjWNQwnuj5hO4tFKLFoHxWwZzCmDFjiIqKYsoXU9h9Yjd3Rt9J/7b98RM/IhtG0rJeS09H9TpaDMonFZ5ojIyMJOvXLFIyUnii5xNM7THV0/G8nk4+Kp9T0tmHzYc3A9CvTT8Pp6satBiUT/nxxx9LPPuwOX0zjWs3JqpRlIcTVg16KKF8SuPGjbnvvvto2bLlb6WQm5/L1qNbGdxusM/f3dlZdI9B+YQdO3Zw6NAhACIiIq66TmHXiV1cuHyh2tzI1Rm0GFSVZ7FYWL9+PXv27Clx/Tfp3xDgF0DPlj3dnKzq0mJQVVrhicZhw4rfsNUYw/q09cQ0i6FOUB0PJKyatBhUlWXvsw+FJf6QyJGfj/j8I+WcTYtBVUnGGLKyskotBYAPv/uQujXr6uXO5aRnJVSVk5OTQ2BgIEOHDiU/P99uKZz+9TQJaQmM7zaemjVqujll1aZ7DKpKSUxM5J133uHChQuIiN1SAFiTuoYr+Ve4u8vdbkzoG7QYVJWRmJhIfHw84eHhBAcHlzr2zMUzLEtZxo3X3kjbBm3dlNB3aDGoKqGgFMqaUygw6+tZnM8+z6x+s9yU0LdoMSivt2fPnnKVwtoDa1l3cB2P9XyM9o3auymlb9HJR+X12rVrR+/evenTp0+ZpZCXn8frW16nU1gnHrrhITcl9D26x6C81v79+8nNzaVWrVr069evzFIA2HpkK8fPH2fSDZMI8NN/9yrK4WIQkSkiclhEskUkRUR6lzE+UERetG1zWUSOicijlY+sqgOLxcLHH39MYmJiubb7cM+HNAhuwIB2A1yUrHpwqFJFZCwwD5gC/Mf2e5yIRBtjjtnZ7J9Ac2ASkAaEAbUqnVj5vMJXNPbo0cPh7U5eOMnGQxuZdMMkAv0DXZjQ9zm6r/UksMIYs9T29Z9EZDAwGXim6GARGQjcBrQxxpy2LT5SyayqGnDkMueSGGN499t3yTf5jO0y1sUpfV+ZhxIiEghcDyQUWZUA3Gxns+HATuBJETkuImki8paIhNh5j0kikiwiyVlZWY6nVz7l4sWLbN26tVylYIxh46GNjHx/JEt3LmVgu4G0qNfCDWl9myN7DA0BfyCzyPJMoL+dbSKAXsBlYBRQD5gPhAPFHvNjjFkCLAGIiYkxDmRSPig4OJgHH3yQunXrOlQKlmMWXtv8Gnsz99L8mua8OvBVRnTUB8Y4g6umbf0AA4wzxpwDEJGpQLyIhBljipaMqsYsFguXL1+mb9++hIaGOrRNQloCj375KE3rNOWvg/7K8Ojh1PCv4eKk1YcjxXAayMM6eVhYGHDKzjYngYyCUrDZb/u9BcX3PlQ1VXhOIT8/Hz+/0o9u800+n+79lGcTnqVzWGeWj16u91lwgTLnGIwxOUAKUPT8zwBgu53NtgHhReYUIm2/Hy1vSOWbik40llUKO37YQeyKWJ5a/xRdm3bVUnAhRw8l5gCrRCQJ6w/9w1jnCxYBiMhKAGPM/bbxHwD/D1guIs9jnWOYB3xijPnRWeFV1ZWYmFiusw/GGKbHTQdg7pC5DGk/RJ8c5UIOFYMx5iMRaQA8BzQFUoFYY0zBv/4tioz/RUT6Y51w3An8DHwOPO2k3KqKCw4OpmPHjowYMcKhicbvTn1HxvkMXh/8OsOiit/CTTmXw5OPxpiFwEI76/qWsOwgMLDCyZRPOnv2LPXq1aNLly507tzZ4du5rzuwjhp+NRjQVq9odAf9rIRyG4vFwttvv01GRgaAw6WQb/JZ9/06erfqzTU1r3FlRGWjxaDcomCisX379jRp0qRc2+4+uZuTF04S217v2+guWgzK5Sp6mXOBtQfWEugfSP+29q6nU86mxaBcKj09vVKlkH4mnQ/3fMjAdgP11KQb6QfWlUu1bt2aoUOH0rVr13KXQl5+HtPjplMzoCbP9n3WRQlVSXSPQblESkoKZ86cQUTo3r17uUsBYFHSInaf3M3ztz1P45DGLkip7NFiUE5nsVj46quvyn2TlcJWfruSOf+Zwx0d7mBoh6FOTKccoYcSyqkKTzQOGjSo3Nv/mvMrS5KW8Hbi2/Rv2583bn9DH13vAVoMymkqe/bhs72f8co3r/DzpZ8ZFjWM2YNn652YPESLQTlFXl4e+/btq3ApHMg6wDPxz9C5SWeWjlhKt/BuLkqqHKHFoCqt4PmR48ePJyAgoNylkJOXw/S46VxT8xoWD19MaLBj92RQrqOTj6pSLBYL7733HleuXCEoKKhCZx/mbZvHvh/38dKAl7QUvIQWg6qwgjmFmjVrlnkvBXsWJC5gUdIixnQew6B25Z+sVK6hhxKqQgpKISoqilGjRpV7T+Gniz/xtuVtVu5ayfDo4bw84GUXJVUVocWgym3nzp2VKoV/7PwH87bP49KVS4y/bjwz+83Um654GS0GVW4tW7ake/fuxMbGlqsUjDHM2z6P+Zb53NbmNqb3nk67hu1cmFRVlM4xKIcdO3YMYwyNGzdm6NCh5S6FOdvmMN8yn7s63cWi4Yu0FLyYFoNyiMViYfny5aSmppZ7W2MMf/vP31iYuJAxncfw6qBX8RP91vNmeiihylT4isbo6OhybWuM4fUtr7Nk5xLu6XoPL/Z/UUuhCtBiUKWqzGXOxhhe2/way5KXcW/Xe3m+//NaClWEFoOy66effmLDhg0Vvsx5zrY5LEtexn3d7mNWv1n6YagqRItB2dWgQQMmTJhA8+bNy10KO4/v5J3EdxjdabSWQhWk+3WqmMTERA4cOABYT02WtxQu5lxkxvoZNK/bnJn9ZmopVEFaDOoqFouF+Ph49u3bV6Ht800+L2x8gWNnjzF78GxqB9Z2ckLlDloM6jeFJxrvvPPOcm+fb/KZ+e+ZfJL6CVNvmsqN197ogpTKHbQYFFD5m6wAvLHlDT787kMm3ziZx3s+7vyQym20GBQA586dq1QpZJzLYHnKckZ1HMW0XtN0XqGK07MS1Vx2djY1a9Zk0KBBGGMq/vHpHQsQEZ7o9YSWgg9w+LtARKaIyGERyRaRFBHp7eB2vUQkV0TKfy2tcimLxcLChQs5d+4cIlLhUvjh7A+sSV3D2C5jaVqnqZNTKk9w6DtBRMYC84BXgW7AdiBORFqUsV19YCXwdSVzKicrmFO49tprCQkJqfDr7Dm5hyfXPYmf+DH5xslOTKg8ydF/Ip4EVhhjlhpj9htj/gScBMr6TlgGvAtYKpFROZkzJhoBXt70MiPeH0H6mXReGvASYSFhTk6qPKXMYhCRQOB6IKHIqgTg5lK2mwKEAXprHi+SmprqlFLYeGgjy1OWM7bLWDZP2szoTqOdnFR5kiOTjw0BfyCzyPJMoMTHD4tIZ2AWcJMxJq+sySgRmQRMAmjRotSjE1VJkZGR9O3bl169elW4FM5eOsuzCc/SvmF7ZvWbRVBAkJNTKk9z+ulKEQkCPgL+bIw57Mg2xpglxpgYY0xMo0aNnB1JYd1TyMnJITAwkD59+lS4FK7kXeGp9U9x5tIZ3rj9DS0FH+VIMZwG8rAeFhQWBpwqYXxTIApYbjsbkQvMBDravh5YmcCq/CwWC2vWrMFiqdxUT05eDo9+9Sj/PvRvnrv1OTqGdXRSQuVtyjyUMMbkiEgKMABYXWjVAGBNCZtkAJ2LLJtiGz8COFKhpKpCCk809urVq0KvYYxh29FtzN02l90ndzOz30zu63afk5Mqb+LoBU5zgFUikgRsAx4GwoFFACKyEsAYc78x5gpw1TULIvIjcNkYo9cyuFFlzz4YY9hyZAvzLfPZdWIXTeo0YU7sHO6MLv/nKFTV4lAxGGM+EpEGwHNYDxVSgVhjzFHbEJ0x9DLZ2dls3769wqVwOfey9bDhf/8mvE44L/V/iVGdRumcQjUhxhhPZ7hKTEyMSU5O9nQMn3Du3DlCQkIqVAqT/zWZzYc389QtTzHx+on61GkfIyIpxpgYe+v1sxI+JjExkXPnzjFw4EDq1q1brm2NMWz43wbe2v4W+7P28+rAVxnbZayLkipvpsXgQxITE4mPjyc6OhpjTJkfZjLGkJufi8Gw6dAm5lvmsz9rPy3rtWThsIUMitRnSVZXWgw+onApjBw58qoPRBljyMnLuerrjekbWZC4gANZB35b3rp+a968/U2GRg0lwE+/Naoz/dv3AUVLoeicwl8S/sLH//242HYRoRE8dvNj+Pv506peKwZHDtZnSCpAi8En1K1bl06dOjF8+PBipZB2Oo3V/11N/7b96da022/LW9VvxYC2A7QIVIm0GKqwM2fOEBoaSlRUFFFRUSWOecvyFsE1gvnroL9Sv1Z9NydUVZXe2q2KslgsLFiwgGPHjtkdczDrIHEH45hw/QQtBVUuWgxVUMEVjR06dKBZs2YljjHGMHuL9fbtf7j+D25OqKo6LYYqxtHLnNekrmHz4c083vNx6tWq596QqsrTYqhCjh496lApnDh/gpc2vcTvmv+OCd0nuDml8gU6+ViFtGjRghEjRtCxY0e7pXA++zyPfPEI+Saf2YNn69OlVYXod00VkJycTFZWFiJCly5dSi2FCZ9MYP+P+5kzZA4t6uln21TFaDF4OYvFwtq1a9mxY0eZY2esn8H+H/ez4M4FDGg7wA3plK/SYvBihScab7/99lLH7jm1hw3/28AjPR7htja3uSmh8lVaDF6qvDdZeWv7W9SrWY+J3Se6J6DyaTr56IXy8/NJS0srsxQu5lzk6NmjHDt3jE3pm5jWaxp1guq4Oa3yRVoMXiYvLw9/f3/uuece/Pz8SiyFC5cv8O6377I8ZTlns88CUL9Wfe7vfr+b0ypfpcXgRSwWC/v27WP8+PEEBRW/hdqFyxdYkbKC5d8u51z2OW6NuJUR0SMI8A+gbWhbQgIr/qg5pQrTYvAShecUAgKK/7Xk5efx4KcPkpyRTP82/ZnaYyqdmxS9GbdSzqHF4AUcmWhc8e0KkjOSmT1oNqM76+PglGvpWQkPS0lJKbMUDv10iDe3vkn/Nv0Z1WmUB1Kq6kb3GDysdevW3HDDDQwaNKjEUjh14RSTPp9EcI1gXh74cpn3cVTKGXSPwUPS09MxxhAaGkpsbGyJpXDywknGfTSOrF+yWDxiMY1q63M9lXtoMXiAxWJh1apV7Nq1y+6YE+dPMO6jcfx08SdW3LWCmGZ2HwGglNNpMbhZwURjVFQUXbt2LXHMD2d/4N6P7uXMxTOsGL2C7uHd3ZxSVXc6x+BGhUth1KhRxQ4fTl44yeIdi/novx8RFBDEyrtW0rVpyeWhlCtpMbjJ2bNn+frrr0sshRPnT7BoxyJWp64m3+QzsuNIHrnpEZrXbe7BxKo602Jwk3r16vHAAw/QpEmT30rhx19+ZN72eaxJXQPA6M6jmfy7yTSrW/J9HJVyFy0GF0tMTCQ4OJguXbpcdePWnLwcfr/m9xw6c4ixXcbyx9/9kfBrwj2YVKn/4/Dko4hMEZHDIpItIiki0ruUsSNFJEFEskTkgojsEJFhzolcdVgsFuLj4/n+++8p+lTxhYkL2Z+1n7eGvsUL/V/QUlBexaFiEJGxwDzgVaAbsB2IExF79w7rA2wEhtjGrwM+K61MfE3hicYRI0ZcdWFSamYqCxMXMjx6uN5pSXklKfovWYmDRHYAe4wxDxValgZ8Yox5xqE3EkkCthpjppU2LiYmxiQnJzvykl6rtLMPl3Mvc+eqOzl/+TxxE+OoW7N8j6pXyhlEJMUYY/fimDL3GEQkELgeSCiyKgG4uRxZ6gA/23mPSSKSLCLJWVlZ5XhJ75SdnW33lOR8y3zSfkrjlYGvaCkor+XI5GNDwB/ILLI8E+jvyJuIyCNAc2BVSeuNMUuAJWDdY3DkNb3RxYsXCQ4Opm/fvhhjrnoUPcDuk7tZnLSYuzrdxa0Rt3oopVJlc/mVjyIyCngDGGeMOerq9/OUgmdJnjlzBhEpVgoHsw7y0KcP0SSkCc/e+qyHUirlGEeK4TSQB4QVWR4GnCptQxEZjXUv4X5jzJcVSlgFFMwptGrVirp1ix8efH/6e8Z/PJ4a/jVYeddKvS+j8nplFoMxJgdIAYpOnw/AenaiRCIyBmspTDTGfFKZkN7MkZusvLn1TQDeH/s+rUNbuzuiUuXm6AVOc4BVtjML24CHgXBgEYCIrAQwxtxv+/purKXwZ2CLiDSxvU6OMeaM8+J71r59+8oshcu5l9l+dDujO42mdX0tBVU1OFQMxpiPRKQB8BzQFEgFYgvNGRS9nuFh22v/3farwGagb8XjepfIyEhuu+02evToYfcW70nHk7iUe4k+EX3cnE6pinP4kmhjzEJgoZ11fUv72tfs2bOHdu3aUatWLXr16lXq2G/SvyEoIIibrr3JTemUqjy9H0M5WSwWPvvsMywWi0PjNx/ezE3X3kStGrVcnEwp59FiKIfCE419+pR9aHDk5yMc/vkwfVv3dXk2pZxJi8FB5X2WJMCm9E0AOr+gqhwtBgfk5OSQlJRUrlJIzkhm7n/m0imsEy3rtXRDSqWcR+/HUAZjDIGBgfz+978nODi41FJIzUwlPi2e3Lxc3tv9Hk3qNGHJiCVuTKuUc2gxlMJisZCVlcXQoUOpU6f0qxWTfkjiD5/+gUtXLuHv50+HRh1YOmIpjUMauymtUs6jxWBH4TkFY4zdB70YY4j7Po4ZcTNodk0z3hv7nj7/QVV5WgwlKDrRWPQDUQD5Jp8NaRuYb5nP/qz9RDWKYsXoFTSs3dADiZVyLi2GInbs2FHq2Yd8k8/679fztuVtDp4+SOv6rXnz9jcZGjWUAD/941S+Qb+Ti2jYsCFdunRh2LBhxUphz8k9zFg/g7Sf0ogIjWBO7Bzu6HAH/n5ln6VQqirRYrDJysqiUaNGtGnThjZt2pQ45vmvn+dc9jn+fsffiY2M1UJQPkuvY8B6i/eFCxeSnp5ud8zezL18d+o7/njjHxnaYaiWgvJp1b4YEhMTiY+PJzo6mpYt7V+I9OGeDwkKCGJE9Ag3plPKM6p1MRQuhdKuaPwl5xe+2PcFQ9oP0Ru4qmqh2s4xZGRklFoKOXk5fLr3U3Ye30nmL5n8euVXxnUd56G0SrlXtS2GZs2acdddd9G+fftiz31Yk7qGd3a8w4kLJwgLCSPIP4jYyFiua3qd5wIr5UbVrhh27txJs2bNCA8PJzo6+rfll3Mv8/F/P2ZR0iJOXThFt/BuvDLwFXq36m33qkelfFW1KoaCOYVu3boxbNgwNqVvYk3qGowx7Dq5i8xfMrm+2fXMHjSbni17aiGoaqvaFEPhicYhQ4aw9sBanlj7BA2CG1C3Zl0iG0byZuyb9Li2hxaCqvaqRTEUlEJg60A2BGwg/l/xbDm8hW7h3Vg2ahkhgSGejqiUV/H5YjDGcPjwYZpHNmfB6QXU+KUGYSFhDOkwhJcHvEztwNqejqiU1/HpYsjNzSUgIIDRo0cz5cspZOdl88m9nxARGuHpaEp5NZ+9wMlisbBs2TIuXbrE6n2r2Zi+kWm9pmkpKOUAnyyGgvsphIaG8lXaV8zcMJPerXozsftET0dTqkrwuWIofJOV/Mh8nkl4hp4te7LozkX6wSelHORTxbBr167fSuFKuyv8ZcNf6NWqF4uHL6ZmjZqejqdUleEzk49nLp4h7qc4tjbayu7Lu9nz7z30ad2Hd+58h6CAIE/HU6pK8YliePvfb7N472IuXblETPMYagbU5P5u9/N0n6e1FJSqAIeLQUSmANOxPu16L/C4MWZrKeP7AHOAjsAJ4HVjzKLKxS3uxU9f5N30d+lUrxNvDH+DyIaRzn4Lpaodh+YYRGQsMA94FegGbAfiRKSFnfGtgXW2cd2A14D5IjLKGaELvLDmBd5Nf5eoWlH8875/aiko5SSOTj4+Cawwxiw1xuw3xvwJOAlMtjP+YeCEMeZPtvFLgXeBP1c+stWsNbNYeXgl0bWiWf3QamoF6dOklXKWMotBRAKB64GEIqsSgJvtbNajhPHxQIyI1ChvyKIWbVvEe4ffo2NwR2spBGopKOVMjuwxNAT8gcwiyzOBJna2aWJnfIDt9a4iIpNEJFlEkrOyssoMFNkkkoGtBvLxgx9TM1BPQyrlbF5xVsIYswRYAhATE2PKGt+vTT/6tenn8lxKVVeO7DGcBvKAsCLLw4BTdrY5ZWd8ru31lFJerMxiMMbkACnAgCKrBmA961ASi53xycaYK+UNqZRyL0fPSswBJorIgyISJSLzgHBgEYCIrBSRlYXGLwKaicjfbeMfBCYCbzoxu1LKRRyaYzDGfCQiDYDnsF7glArEGmOO2oa0KDL+sIjEAnOxntI8ATxqjFnjtORKKZdxePLRGLMQWGhnXd8Slm0Gulc4mVLKY3zq05VKKefQYlBKFaPFoJQqRowp83oitxKRLOBomQOtV1B68zUR3pzPm7OBd+fz5mzgeL6WxphG9lZ6XTE4SkSSjTExns5hjzfn8+Zs4N35vDkbOC+fHkoopYrRYlBKFVOVi2GJpwOUwZvzeXM28O583pwNnJSvys4xKKVcpyrvMSilXESLQSlVjBaDUqoYry0GEZkiIodFJFtEUkSkdxnj+9jGZYtIuog87C35RGSkiCSISJaIXBCRHSIyzBuyFdmul4jkikiqq7JVJJ+IBIrIi7ZtLovIMRF51EuyjROR3SJyUUROich7ImLvloeVyXWLiHwhIhkiYkRkogPbdBaRzSJyybbdTBERh97QGON1v4CxwBXgISAKmA/8ArSwM7418KttXJRtuyvAKC/JNw94Gvgd0BaYhfWuWL09na3QdvWBdKw37U31lr9b2zafAklYb/bTCrgR6OvpbEBP29/jE7bvwZuAb4GvXZAtFuvjG0YDF4GJZYy/Buud1D4GOtm2uwBMc+j9XPUNUMk/hB3A0iLL0oDX7IyfDaQVWfYPwOIN+ey8RhLwN2/JZvvhmwU87+JiKO/f7UDgHNDQld9zFcz2Z+BokWUPAL+4OOcvDhTDZOA8UKvQsueADGxnI0v75XWHEt54u3on5CtJHeBnZ+WCimezPWUsDHjZmXlKeJ+K5BsO7ASeFJHjIpImIm+JSIgXZNsGNBWRoWLVELgb68OWPK0HsNUYc6nQsnisd15rVdbGXlcMuOF29ZVUkXxXEZFHgObAKudGK382EemMdU9hvDEmz8l5iqrIn10E0AvoCowCpgKDgRWezmaMsWAtgveBHCALEGCCk7NVhL2fiYJ1pfLGYvBptsf0vQGMM/93azxPZQkCPgL+bIw57MkspfADDNY/rx3GmHis5TBKRIreidytRCQa6zzES1j3NgZj/aFb7MlczuAVz5UowttvV1+RfACIyGhgJXC/MeZLJ+eqSLamWCfZlovIctsyP2tUycV6X8+iu9buzAfWRyFmGGPOFVq23/Z7C4r/q+jObM8AScaYN2xf7xGRX4GtIvIXY8xxJ2WrCHs/EwXrSuV1ewzGy29XX8F8iMgYrIcOE40xnzgzUyWyZQCdgesK/VoE/M/233b/f9yUD6zH8eFF5hQKnl7stD2uCmYLxlomhRV87emfLQvQW0QKP6ptANYbMx8pc2tXz/RWcNZ1LNZjtgex/os2D+tMbEvb+pXAykLjC05X/t02/kHb9q48XVmefHdjPQ32GNZdzYJfoZ7OVsL2z+P605Xl+bMLAX4AVgMdsZ4iTAVWe0G2iba/18lY50J6Yp0oTXFBthD+r7wvAjNt/93Ctv41Cp0mBepi3TP4J9bTlSOxnqWouqcrbf9jU7A222WsTX5LoXXfAN8UGd8H6znky8Bh4GFvyWf72pTw6xtPZythW5cWQwX/bttjPTtwEetezgKgjpdk+xOw15btJNaJyOYuyNXXzvfQCtv6FcCRItt0BrYA2bZss3DgVKUxRj9dqZQqztPHQUopL6TFoJQqRotBKVWMFoNSqhgtBqVUMVoMSqlitBiUUsVoMSilivn/GGWEVPINHyIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.00013950661084881664,\n",
       " 'area_below': 0.04350163003878188,\n",
       " 'total_area': 0.043641136649630694}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_k5\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "# set ticks bigger\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"SBM_knnBootstrap_k{k}_M{M}_SYMM.png\", facecolor=\"white\")\n",
    "\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_k5, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-kNN k=25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "k=25\n",
    "\n",
    "p_vals_k25 = []\n",
    "A_boots_list_k25 = []\n",
    "\n",
    "for m in A_true_draws:\n",
    "    p_val, A_boots = create_single_kNN_bootstrap(m, d=d, Q=1000, n_neighbors=k)\n",
    "    p_vals_k25.append(p_val)\n",
    "    A_boots_list_k25.append(A_boots)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0004531489777893149,\n",
       " 'area_below': 0.04978944376939483,\n",
       " 'total_area': 0.050242592747184144}"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_k25\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"SBM_knnBootstrap_k{k}_M{M}_SYMM.png\", facecolor=\"white\")\n",
    "\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_k25, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-kNN k=55"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "k=55\n",
    "\n",
    "p_vals_k55 = []\n",
    "A_boots_list_k55 = []\n",
    "\n",
    "for m in A_true_draws:\n",
    "    p_val, A_boots = create_single_kNN_bootstrap(m, d=d, Q=1000, n_neighbors=k)\n",
    "    p_vals_k55.append(p_val)\n",
    "    A_boots_list_k55.append(A_boots)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.00011259673564540132,\n",
       " 'area_below': 0.05294405899624757,\n",
       " 'total_area': 0.05305665573189297}"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_k55\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"SBM_knnBootstrap_k{k}_M{M}_SYMM.png\", facecolor=\"white\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_k55, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-kNN k=90"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "k=90\n",
    "\n",
    "p_vals_k90 = []\n",
    "A_boots_list_k90 = []\n",
    "\n",
    "for m in A_true_draws:\n",
    "    p_val, A_boots = create_single_kNN_bootstrap(m, d=d, Q=1000, n_neighbors=k)\n",
    "    p_vals_k90.append(p_val)\n",
    "    A_boots_list_k90.append(A_boots)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 7.7038108871609e-07,\n",
       " 'area_below': 0.06118075716866658,\n",
       " 'total_area': 0.061181527549755296}"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_k90\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"SBM_knnBootstrap_k{k}_M{M}_SYMM.png\", facecolor=\"white\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_k90, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-$YY^T$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/uj21900/Documents/ValidBootstrapsForNetworks/functions_for_bootstrap.py:227: UserWarning: P_hat contains values outside of [0,1]. The values outside this range will be clipped to lie in the range.\n",
      "  warnings.warn(\"P_hat contains values outside of [0,1]. The values outside this range will be clipped to lie in the range.\")\n"
     ]
    }
   ],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_YYT = []\n",
    "A_boots_list_YYT = []\n",
    "\n",
    "for m in A_true_draws:\n",
    "    p_val, A_boots = create_single_YYT_bootstrap_cropPto0_1range(m,d=d,Q=1000)\n",
    "    p_vals_YYT.append(p_val)\n",
    "    A_boots_list_YYT.append(A_boots)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 1.5275360138129352e-05,\n",
       " 'area_below': 0.02298035794464735,\n",
       " 'total_area': 0.02299563330478548}"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_YYT\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_YYTbootstrap_M{M}_SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_YYT, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-Sample edgelist with replacement bootstrap for each draw from the model\n",
    "\n",
    "This is essentially just dropping some edges, as any edge selected more than once is set to a 1 as this is a binary setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_ESWR = []\n",
    "A_boots_list = []\n",
    "\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    A_boots = edgelist_sample_with_replacement(m) \n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_ESWR.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.4999489847974696,\n",
       " 'area_below': 0.0,\n",
       " 'total_area': 0.4999489847974696}"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_ESWR\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_edgelistSampleRepBootstrap_M{M}_SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_ESWR, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ASE-edgelist sample with replacement then rand sample edges"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_ESWR_plusRand = []\n",
    "A_boots_list = []\n",
    "\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    A_boots = edgelist_sample_with_replacement_addRandomEdges(m) \n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_ESWR_plusRand.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.4999489847974696,\n",
       " 'area_below': 0.0,\n",
       " 'total_area': 0.4999489847974696}"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_ESWR_plusRand\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_edgelistSampleRepBootstrap_edgesAdded_M{M}_SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_ESWR_plusRand, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ProNE-kNN d=4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN with k=5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k5_d4 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=5\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k5_d4.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.09827619630649936,\n",
       " 'total_area': 0.09827619630649936}"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k5_d4\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_d{d}SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k5_d4, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k25_d4 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=25\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k25_d4.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQYAAAD8CAYAAACVSwr3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAAsTAAALEwEAmpwYAAAojUlEQVR4nO3deVyVZf7/8dcHEBVxSUVxw12/4JaC5a6VS2puqS1m2eqUWpnVVE4zTctU0zZZbln9ctTKpW1aNNQay/KgQpqiZZo7iqEmJijr9fvjHJoTcOQI55z7Bj7Px4OHcq8fBd5c93Xd93WLMQallHIXZHUBSin70WBQShWhwaCUKkKDQSlVhAaDUqqIEKsLKKx+/fqmRYsWVpehVIWWlJR03BgT4Wm97YKhRYsWJCYmWl2GUhWaiBw433q9lFBKFaHBoJQqQoNBKVWEBoNSqggNBqVUEV4Fg4j0E5GPRSRFRIyI3OzFPp1E5CsROeva728iImWuWCnld962GMKBZOBe4GxJG4tILWANcAzo7trvQWBG6cpUSgWSV8FgjFlpjJlpjHkPyPdilxuAMGCSMSbZtd8/gRnaalDKP+Z+O5fVu1f75Fj+6mPoCaw3xri3LuKBxkCLwhuLyGQRSRSRxLS0ND+VpFTF9eOPP/LqhldZ/YO9gyES52WEu2Nu6/7AGLPAGBNnjImLiPB4l6ZSyoPQiFCyJZvYqFifHE9HJZQqx77//nsyMjLYkbYDgM6NOvvkuP56ViIVaFhoWUO3dUqpMnI4HKxevZrevXuTHJJMaHAobeu39cmx/dVicAB9RaSa27JBwBFgv5/OqVSlURAKMTExXHbZZWw/tp3oiGhCg0N9cnxv72MIF5GLReRi1z5Rrs+jXOufEZEv3HZ5B8gEFopIRxG5GngYeMno7LNKlYl7KFx99dVIkLDj2A46Nuzos3N422KIA7a4PqoDj7v+/oRrfSOgdcHGxph0nC2ExkAiMAd4EXjJJ1UrVUnl5OSQlJT0eygEBwdz4NcDnMk+Q6fITj47j1d9DMaYdYDH+w+MMTcXs2w70K+0hSml/sgYQ5UqVbjllluoVq0awcHBAGw/th3Ap8GgoxJKlQMOh4MPPviA/Px8atSo8XsoAGxP3U7VkKq0qdfGZ+fTYFDK5gr6FPLz8ymuiy75WDIxETGEBPlukFGDQSkbK9zR6N5SADh97jRbj24ltolvbmwqoMGglE1t3LjxvKEAsGbPGrLzshnWfphPz227yWCVUk6RkZF06dKFESNGFBsKACt3raRJrSZ0jvTNHY8FNBiUspnU1FQiIyNp3rw5zZs397hd+rl0vjnwDbfE3oKvH1rWSwmlbCQhIYHXXnuN3bt3l7jtmt1ryM3PZXj74T6vQ4NBKZtISEggPj6emJgYWrVqVeL2n+76lKjaUT6947GABoNSNuAeCp46Gt3t/GUn6/evZ0yHMT6/jAANBqUsd/To0QsKBYBXNrxCzao1ubnbzX6pSTsflbJYo0aNuP7662ndurVXoZB8LJk1e9Zwb697qVWtll9q0haDUhbZtGkTBw8eBKBdu3ZehYIxhn998y9qVa3FLbG3+K02DQalLJCQkMCqVavYsmXLBe336a5PWbdvHVN6TKFm1Zp+qk6DQamAc+9ovOqqq7zeLy0jjb+v/TtdG3Xl1thb/VihBoNSAXWhow/uHlv7GGdzz/Lc0OcIDvJ+v9LQYFAqQIwxHD58uFShsPXoVuJ3xzO1x1Ra1S35Hoey0lEJpQIgJyeHKlWqcPXVV2OMuaBQAHj525epW72u34YnC9MWg1J+5nA4WLBgAZmZmQQFBV1wKHx35DvW71/PHd3voEZoDT9V+UcaDEr5UcF8Cg0aNKBq1aoXvL8xhhfXv0i9sHpMvHiiHyosngaDUn5S0iQr3li+fTkJhxK4t9e9hIWG+aHK4mkwKOUHW7duLXMopKSn8PS6p+kZ1ZPru1zvhyo9085HpfygTZs29OrVi8svv/yCQ8EYw8ZDG/nHun9gjOHZIc8SJIH9Ha4tBqV8aNeuXeTl5REeHs6gQYNK1VK477P7uGH5DRzPOM6Lw1+kae2mfqj0/DQYlPIRh8PB0qVL2bx5c+mPcdDBJz9+wm2xt/Hf2//LoDaDfFih9zQYlPIB947G7t27l+oYxhhmbZhFgxoNmNFnBtWqVCt5Jz/RYFCqjHwx+gCw4eAGNh/ezF2X3mVpKIAGg1JlcubMGb766qsyh0Jefh4vffMSkeGRXNv5Wh9XeeF0VEKpMggPD+e2226jbt26pQ4FgIXfLWTr0a28MPQFqoZc+I1QvuZ1i0FEpojIPhE5JyJJItK3hO0niMhWEckUkVQRWSIikWUvWSnrORwONmzYAEBERESZQuHnEz/zwvoXGNh6IKNjRvuowrLxKhhE5FpgFvA00BXYAKwSkSgP2/cGFgP/BjoAo4EY4O2yl6yUtQr6FFJSUop9l+SFMMYwc/VMwqqE8dTgp/wysWtpeNtimAEsNMa8boz5wRhzN3AUuMvD9j2Bw8aYfxlj9hljEoBXgUvLXrJS1inc0VjWH+Sv9n1FYkoiD/R9gIgaET6qsuxKDAYRCQVigdWFVq0GennY7VugkYiMEKf6wHXAyrIUq5SVEhISfDL6UKBgeLJpraaM6zjOR1X6hjcthvpAMHCs0PJjQLF9BsYYB84geBvIBtIAASYVt72ITBaRRBFJTEtL87J0pQIrODjYZ6EAsG7vOralbmNqz6lUCa7igwp9xy/DlSISg/PS4UmcrY0rcYbIa8Vtb4xZYIyJM8bERUTYpzmlFMDp06cB6N69O+PGjfNJKJzIPMEzXz1DVO0oxsSMKfPxfM2bYDgO5AENCy1vCKR62OcRYJMx5nljzDZjTDwwBbhRRAJ/47dSpeRwOJg9ezapqc5vdV90Dh7POM7E5RM5fPowTw952natBfAiGIwx2UASUPim7UE4RyeKE4YzTNwVfK43ValyoaCjsU2bNviqJZudl82tH9zKwVMHeePqN+gZ1dMnx/U1b29weglYLCKbcHYs3gk0BuYDiMgiAGPMTa7tPwFeF5G7gHigEfAy8J0x5qDPqlfKTwpCITo6mrFjx/rk8gFgjmMOO47tYN6oefSK8tR3bz2vgsEYs0xE6gGP4vwhTwaGGWMOuDaJKrT9QhGpCUwDXgTSgS+Bh3xVuFL+snv3br+EwvbU7czbOI8xMWMY3HawT47pL1LWGzR8LS4uziQmJlpdhqrE8vPzSUxMJDY21mehkJWbxajFoziddZpVN6+idrXaPjluaYlIkjEmztN6vd5XymXLli2cPn2aoKAgLrnkEp+FAjjfTr37xG6eHvy05aHgDQ0GpXD2KXz88ce/P//gS1uObGHB5gVc0+kaBrQa4PPj+4MGg6r03DsaBw3y7YxJR04fYfqn02kY3pCZA2b69Nj+pI9dq0rNX6MPAIfTD3PDshtIz0pn0bhFfn07ta9pMKhKKzc3l++//95voTBh2QR+y/qNReMX0Tmys8+OHQgaDKpSMsYQEhLCpEmTCA0N9WkoHDx1kBuW3UBGTgaLr1lMx4YdfXbsQNE+BlXpOBwOli1bRl5eHtWrV/dpKBw4dYDrl11PZk4mS65ZUi5DATQYVCVT0KfgyzAosO/XfUxYOoGs3CyWXLOEmAYxPj9HoOilhKo0fDWbc2EnMk/w+ubXWbJlCdWrVOfta96mfUR7nxzbKhoMqlLYtGmTX0Lh5xM/M3H5RI5nHueq/7uK6b2n07xOc58c20oaDKpSaNq0KV27dmX48OE+C4U9J/YwcflE8k0+/7nxP+X60qEw7WNQFVpKSgoAjRs3ZuTIkT7tW7jnk3swxvDOte9UqFAADQZVgTkcDt544w1++OEHnx97V9oudh3fxT297qFNvTY+P77VNBhUheTe0diuXTufH3/lrpUESRBD2g7x+bHtQINBVTj+Gn0oYIxh5U8rubTZpdSvUd+nx7YLDQZVofzyyy9+DQWAXcd3sffkXoa1H+bzY9uFjkqoCqVBgwbceOONNG/e3C+hAPDpj59W6MsI0BaDqiA2btzIzz//DECrVq38FgpZuVl8uPNDekb1pF5YPb+cww40GFS553A4+Pzzz9m2bZvfz7Vi+wpSf0vlju53+P1cVtJgUOWae0fjyJEj/XqurNws5m2cR2yTWPo07+PXc1lNg0GVW/4efShs2bZlpJ5J5d5e99rmrdT+osGgyiVjDGlpaQELhc2HN/P8+ue5pOkltn4fhK/oqIQqd7KzswkNDWXEiBHk5+f7PRQ2HdrEbR/cRmTNSF6+6uUK31oAbTGociYhIYF58+bx22+/ISJ+D4XjGceZ8vEUImtG8vY1b9MwvPArXCsmDQZVbiQkJBAfH0/jxo0JCwvz+/mMMfxlzV/IyM5g3qh5NAhv4Pdz2oUGgyoXCkIhUH0KAP/54T+s3bOWGX1mVMgHpc5Hg0HZ3rZt2wIeCt/s/4aZq2cS2ySWW2Nv9fv57EY7H5XttW3blr59+9K/f/+AhML6/euZ/OFkWtdtzfxR8wkO8v857UZbDMq2fvjhB3Jzc6levTqXX355QEIhMzuTGZ/NoFXdViy+ZjF1w+r6/Zx25HUwiMgUEdknIudEJElE+pawfaiIPOHaJ0tEDorIPWUvWVUGDoeD5cuXk5CQENDzLt66mJNnT/LUoKe4qPpFAT23nXh1KSEi1wKzgCnAN64/V4lIjDHmoIfdlgJNgcnAbqAhUL3MFasKz/2Oxp49ewbsvBnZGbyx+Q36tehH18ZdA3ZeO/K2j2EGsNAY87rr87tF5ErgLuCRwhuLyGDgCqC1Mea4a/H+MtaqKoFA3+bsbvEWZ2theu/pATunXZV4KSEioUAssLrQqtWAp3tDRwObgRkiclhEdovIKyIS7uEck0UkUUQS09LSvK9eVSiZmZmsX7/eklDIN/ks3rKYvi360qVRl4Cd1668aTHUB4KBY4WWHwMGetinFdAHyALGAnWAV4HGwLjCGxtjFgALAOLi4owXNakKKCwsjNtvv53atWsHNBQAvkv5jtQzqTzU/6GAnteu/DVcGQQYYIIxJh1ARKYB8SLS0BhTOGRUJeZwOMjKymLAgAHUrWvNKMBnuz4jNDiUy1tfbsn57cabUYnjQB7OzkN3DYFUD/scBVIKQsGlYA7vqAuqUFVoBX0KaWlp5OfnW1JDXn4en//0OQNaDSA8tNir3UqnxGAwxmQDScCgQqsGARs87PYt0LhQn0LBHN4HLrRIVTEV7mgMCrLmtpqklCR+yfiF4e2HW3J+O/L2K/EScLOI3C4i0SIyC2d/wXwAEVkkIovctn8HOAG8JSIdRKQ3zuHO94wxv/iwflVOJSQkWDb64C43P5el25ZSLaQal7W6zJIa7MirPgZjzDIRqQc8CjQCkoFhxpiC3/5RhbY/IyIDcXY4bgZ+BT4CHvZR3aqcCwsLo0OHDowZM8ayUIjfHc+zXz3LwVMHub7L9dQIrWFJHXYkxthrECAuLs4kJiZaXYbyk1OnTlGnTh3A+VizVZOerNi+gkfiH6F9RHum957OwNYDK8UELAVEJMkYE+dpvT4roQLG4XAwe/bs3180a9UP4rJty3g4/mH6tOjD+xPeZ1CbQZUqFLyhwaACoqCjsX379kRGRlpWxzvfv8PM1TPp37I/r41+jWpVqllWi51pMCi/s/I2Z3crtq/gr2v+ymWtLmPeqHlUDalqSR3lgQaD8qu9e/faIhQA5iTMoVvjbswZOUdDoQQ6UYvyq5YtWzJixAi6dOliaSikZaRxKP0QN3a9UUPBC9piUH6RlJTEyZMnERG6detmaSgAfHfkO4BK/zi1tzQYlM85HA4+/fTTgE+ycj7fpXxHaHAoHRp0sLqUckGDQfmUe0fjkCH2eU38lqNb6NCwg15GeEmDQfmMXUYfCsvOy2Z76na6NepmdSnlhgaD8om8vDx27txpu1AA2PnLTrLzsunWRIPBWzoqocqs4P2REydOJCQkxFahALDlyBZAOx4vhLYYVJk4HA6WLFlCTk4OVatWtV0ogPNN1Y1rNq407530BQ0GVWoFfQrVqlWzbC6FkiSlJLF692oGtx1sdSnlij2/msr2CkIhOjqasWPH2rKlcDbnLH/+/M80rtWY+/rcZ3U55Yr2MagLtnnzZtuHAsCL37zI/l/3s/iaxTpl2wXSYFAXrHnz5nTr1o1hw4bZNhQ2HdrEwqSF3HjxjfSK8vSWA+WJXkoorx08eBBjDA0aNGDEiBG2DYWM7Awe+vwhmtVuxp/7/dnqcsolDQblFYfDwVtvvUVycrLVpZyXMYYnv3ySQ+mHeG7oc4SFhlldUrmkwaBK5H5HY0xMjNXleGSM4fEvHmdF8gru6nEX3Zt2t7qkckuDQZ2XXW9zLs5zXz/H4q2LuT3udmb0nmF1OeWaBoPy6MSJE6xZs6ZchMKBUwd4M/FNxnccz8P9H9Y5HMtIRyWUR/Xq1WPSpEk0bdrU1qEAMMcxh5DgEGb0maGh4APaYlBFJCQk8OOPPwLOoUm7h8K+X/fx0c6PmNBlAg3CG1hdToWgwaD+wOFwEB8fz86dO60uxSu70nbxSPwjVAmuwp8u+ZPV5VQYeimhfufe0Thq1CiryylWXn4ez3z1DBsObCDf5LP7xG5qVKnBXy//KxE1Iqwur8LQYFBA+Rh9yMvP48FVD/KfH/5Dn+Z9CAsN48p2VzKp2yQuqn6R1eVVKBoMCoD09HRbh0LysWReWP8C6/ev5/4+9zOlxxSrS6rQNBgquXPnzlGtWjWGDBmCMcZ2j0/n5ufyl9V/4b3k96hVtRZ/v+Lv3Nj1RqvLqvC8/i4QkSkisk9EzolIkoj09XK/PiKSKyL2vpe2EnI4HMydO5f09HRExHahkJOXw32f3sd7ye8xuftkvp78tYZCgHj1nSAi1wKzgKeBrsAGYJWIRJWw30XAIuCLMtapfKygT6FZs2aEh9vzkeSZq2ey8qeVzBwwk4f6P0TNqjWtLqnS8PZXxAxgoTHmdWPMD8aYu4GjwF0l7Pcm8G/AUYYalY+Vh47Gz3/6nA92fMC0HtO4Le42q8updEoMBhEJBWKB1YVWrQY8PuguIlOAhsBTZSlQ+VZycrLtQ+F4xnH+uuavdGzYkWk9p1ldTqXkTedjfSAYOFZo+TFgYHE7iEgn4DGghzEmr6RbVEVkMjAZICrqvFcnqozatWvHgAED6NOnjy1DISs3iwdXPciZ7DM8P/R5qgRXsbqkSsnnvU0iUhVYBjxgjNnnzT7GmAXGmDhjTFxEhN6k4g/JyclkZ2cTGhpK//79bRsKUz+eytf7v+axKx6jXf12VpdUaXnTYjgO5OG8LHDXEEgtZvtGQDTwloi85VoWBIiI5ALDjDGFL0uUHxX0KQwYMID+/ftbXc4fZOVm8cCqB1i/fz25ebmczT3LU4Oe4rrO11ldWqVWYjAYY7JFJAkYBKxwWzUIeL+YXVKAToWWTXFtPwbYX6pKVam4dzT26dPH6nL+ICs3izs/upOv93/NuI7jCA8Np0dUDwa1GWR1aZWetzc4vQQsFpFNwLfAnUBjYD6AiCwCMMbcZIzJAf5wz4KI/AJkGWP0XoYAsuvogzGG/+79Ly9/+zI7f9nJs0OeZXyn8VaXpdx4FQzGmGUiUg94FOelQjLOS4IDrk20x9Bmzp07x4YNG2wVCsYY1v68llcdr7Lj2A6a1W7GnJFzGNLOPm/FVk5ijLG6hj+Ii4sziYmJVpdRIaSnpxMeHm6bULj7k7tZ9dMqoupEMfXSqYyKGaWjDhYRkSRjTJyn9fqsRAWTkJBAeno6gwcPpnbt2laX87v3d7zPqp9WMa3HNO7udTchQfqtZ2f2ujlelUlCQgLx8fGcPn0aO7UEj5w+wpNfPkn3pt25t/e9GgrlgAZDBVEQCgV9CnZ6IOrxLx8nLz+Pf175T4LEPnUpz/SrVAEUDgU79CkU2HZ0G2v3rOXOS++keZ3mVpejvKRtugqgdu3adOzYkdGjR9sqFABmbZhFnWp1mNRtktWlqAugwVCOnTx5krp16xIdHU10dLTV5RSx9ehW1u1bxwN9H9BHpssZvZQopxwOB3PmzOHgwYNWl1JEdl42S7ctZdrH07io+kU6uUo5pC2Gcsj9jsYmTZpYXQ65+bmcOnuKfJPP2j1rmbdxHkd+O0KXyC7MvGwm4aH2nAhGeabBUM7Y6TbnrNwslm9fzvxN80n97X/P03Vt3JWnBj9Fvxb99K1Q5ZQGQzly4MAB24TCqbOnmPTeJJKPJRPbJJY/df8TwUHBtK7bmkubXaqBUM5pMJQjUVFRjBkzhg4dOlgaCr+e/ZWbVtzEnhN7nM86tB2iQVDBaDCUA4mJiTRv3pyIiAg6d+5sWR2Z2Zm8u+1dFmxawOms07w2+jX6texnWT3KfzQYbK6gTyE2NparrrrKkhoysjNYsnUJb2x+g5NnT9IrqhcP9n2Qzo2sCynlXxoMNube0Th06NCAnz8jO4PFWxbzZuKbnDx7kr4t+jKt5zTimnh8KE9VEBoMNmWH0YcZn81g7c9r6deiH3f3uptujbsFvAZlDQ0GG8rPz2f37t2WhsKhU4f44ucvmNJjCvf3uT/g51fW0mCwmby8PIKDg7n++usJCgqybPRh2fZliAgTukyw5PzKWnpLtI04HA4WLlxIVlYWVapUsSwUcvJyWLF9BZe3upxGNRtZUoOylgaDTRT0KdSqVYuQEGsbcmv3rOV45nGu66JTuFdWeilhA3boaATnjUsLNi1gydYlNKvdjH4t9B6FykqDwWJJSUm2CIWU9BRuWH4Dh9MPc9X/XcX03tMJDrLX3A4qcDQYLNayZUu6d+/OkCFDAh4Kp8+dZucvO8nKy+Jva/5GelY6KyasoGvjrgGtQ9mPBoNF9u7dS8uWLalbty7Dhg0L+PkPnTrEDctvIOV0CgC1qtZi0fhFdI7UuxmVBoMlCvoURowYQbdugb9p6OCpg9yw7AYycjKYM3IOdarVoXW91kTU0BcKKycNhgArCIXo6Gi6dOliSQ0zV88kIyeDxeMX06FhB0tqUPamw5UB5B4KY8eOtaSjce/JvTgOOpjcfbKGgvJIgyFATp06xRdffGFpKAAs/X4pIUEhjOs4zpLzq/JBLyUCpE6dOtxyyy1ERkZaFgpZuVm8v+N9BrcdTP0a9S2pQZUPGgx+lpCQQFhYGJ07d7Zs4tb9v+5n5y872XFsB6fOneL6LtdbUocqP7wOBhGZAjwINAJ2ANONMes9bHs1cCfQFagG7AT+YYz5uMwVlyMFfQodOnSgU6dOAZ/+bO/Jvcx2zOaTHz8h3+QD0LZeW3o26xnQOlT541UwiMi1wCxgCvCN689VIhJjjCnuxQb9gS+BR4GTwA3AhyIywFOYVDTuHY1jxowJaCikpKfw/Prn+fTHT6kWUo1bY29lVMwoQoJCaFSzkc7PqEok3rwVWUQ2AtuMMXe4LdsNvGeMecSrE4lsAtYbY877cH9cXJxJTEz05pC2ZfXow7XvXsuOYzu4qdtN3BZ3G/XC6gX0/Mr+RCTJGONxKq4SWwwiEgrEAi8UWrUa6HUBtdQEfvVwjsnAZHDOhFzenTt3zrJQ2JW2i8SURB7u/zB3dL+j5B2UKoY3lxL1gWDgWKHlx4CB3pxERKYCTYHFxa03xiwAFoCzxeDNMe0oMzOTsLAwBgwYgDHGklfRv7vtXUKDQxnbYWzAz60qDr9/54rIWOB5YIIx5oC/z2eVgndJnjx5EhGxJBTO5pzlo50fcWW7K6kbVjfg51cVhzffvceBPKBhoeUNgdSim/+PiIzD2Uq4yRjzSakqLAcK+hRatGhB7dq1Lavjsx8/47es33Q6NlVmJQaDMSYbSAIGFVo1CNjgaT8RuQZnKNxsjHmvLEXamV0mWQF45/t3aFO3jU7vrsrM2/buS8DNInK7iESLyCygMTAfQEQWiciigo1F5DrgbeBh4GsRiXR9VKj27c6dO20TCjuO7eD71O+5rst1Ohypysyr+xiMMctEpB7O+xIaAcnAMLc+g8JDCXe6jv2y66PAV8CA0pdrL+3ateOKK66gZ8+eloYCODsdq4ZU5eoOV1tah6oYvL7z0RgzF5jrYd2A831e0Wzbto22bdtSvXp1+vTpY3U5nMk+w8c7P2Z4++HUrmZdH4eqOPTpygvkcDj48MMPcTgcVpcCgDGGt7e+TUZOhnY6Kp/Rh6gugHtHY//+/S2txRjD+v3recXxCluObCG2SSwXN7rY0ppUxaHB4CW7jD4YY1i3bx2zHbPZenQrjWo24omBTzCu4zjtdFQ+o8HghezsbDZt2mRJKBQEwdYjWzE4WwnbUrfRpFYTnhr0FGM7jiU0ODRg9ajKQYOhBMYYQkNDufXWWwkLCwtoKCSmJPLkl0+SfCwZAEFoVqcZzwx5hjExY6gSXCVgtajKRYPhPBwOB2lpaYwYMYKaNWsG9NzfHviWOz68g4iwCP455J+MihmlQaACRoPBA/c+BWNMQK7fvz/6PSt3rSQ3P5d3t71Ly4tasmj8In1sWgWcBkMxCnc0BuKBqNz8XKZ/Np2U9BRCg0Pp1LAT80bN04ehlCU0GArZuHGjJaMPH+34iIOnDjJ/9HwGtSn8WIpSgaXBUEj9+vXp3LkzI0eODFgo5OTlMDthNh0admBga6+muFDKrzQYXNLS0oiIiKB169a0bt06YOfNzc9l3sZ5HEo/xOuXv673Iihb0FuicU7xPnfuXPbu3RvQ867bu45Bbw5i1oZZ9GvRj8taXRbQ8yvlSaVvMSQkJBAfH09MTAzNmzcP2Hnjf4rnnk/voVXdVrw2+jWuaH2FthaUbVTqYHAPhUB1NGblZrF021L+8d9/0LlRZ94a+xY1qwb2HgmlSlJpgyElJcWvoZCVm8X7ye+TdCTp92XGGDYd3sTR347Su3lv5o6aS3houE/Pq5QvVNpgaNKkCePHj6d9+/Y+D4XVu1fz+BePk3omlcjwyD88y9DiohY8O+RZejfvrZcOyrYqXTBs3ryZJk2a0LhxY2JiYnx+/I9/+Jj7V95PdEQ0zw19jl5RvTQAVLlTqUYlEhISWLlyJf5409XZnLO8tvE17l95P3FN4nj3une1VaDKrUrTYnDvaBw+fHiZjvXtgW9ZsnUJBa/3Mxi2HNnCicwTXNH6Cl4e/jJhoWG+KFspS1SKYPDl6MPR344y9eOphAaHElEj4vflXSK78KdL/kRcU526XZV/FT4YjDHs27fPJ6FgjGFm/Exy83L5aOJHtLiohe8KVcpGKnQw5ObmEhISwvjx4xGRMo8+LNqyiK/3f81jlz+moaAqtArb+ehwOHjzzTc5e/YsISEhZQ6FpduW8sSXT3BZq8uY2HWij6pUyp4qZIvBfT6F0NALmw8x/Vw6//7u32w8tPH3Zfkmn02HN9GvRT/mjJxDkFTYPFUKqIDBUNrZnE+dPcVbSW+x8LuFnMk+Q+fIzlQNqfr7+gldJvDoZY/+YZlSFVWFCoYtW7ZccCj8evZX3kx8k8VbFnMm+wxXtr2SaT2nEd0gOgAVK2VPFSoYWrduTY8ePRg4cOB5Q+G97e+xdPtSMPDT8Z/IzMlkaPuhTOsxjfYR7QNYsVL2VCGCYc+ePbRq1YpatWoxZMiQ82676LtFPP7l47Sv354G4Q0Y2n4ot8XdRrv67QJUrVL253UwiMgU4EGcb7veAUw3xqw/z/b9gZeADsAR4DljzPyylVtUQZ9Cr4G9SMxJZOOhjRhMsdsaY9jxyw4GthnIqyNe1Re1KOWBV8EgItcCs4ApwDeuP1eJSIwx5mAx27cEVgL/D5gI9AHmikiaMeZ9XxXvcDj4aM1HpEamsnzzcrLzsrm02aVUC6nmcZ+eUT25v+/9GgpKnYe3LYYZwEJjzOuuz+8WkSuBu4BHitn+TuCIMeZu1+c/iMilwAOAT4Jh5bqVzHHMYU+NPZgzhpHRI5naYyot67b0xeGVqtRKDAYRCQVigRcKrVoN9PKwW0/XenfxwCQRqWKMybnQQt3NXj+bVza/gqliGB09mqk9p+qdiEr5kDcthvpAMHCs0PJjgKe5ziOBtcVsH+I63lH3FSIyGZgMEBUVVWJBrRu0ZmiboUzvN52W9bSFoJSv2WJUwhizAFgAEBcXV3zPoZuh7YcytP1Qv9elVGXlzb29x4E8oGGh5Q2BVA/7pHrYPtd1PKWUjZUYDMaYbCAJKPzetEHABg+7OTxsn1jW/gWllP95+zTQS8DNInK7iESLyCygMTAfQEQWicgit+3nA01E5GXX9rcDN1O0A1MpZUNe9TEYY5aJSD3gUZw3OCUDw4wxB1ybRBXafp+IDAP+hXNI8whwjy/vYVBK+Y/XnY/GmLnAXA/rBhSz7CugW6krU0pZRicWUEoVocGglCpCg0EpVYQUvBvBLkQkDThQ4obOOyjtfE+Eneuzc21g7/rsXBt4X19zY0yEp5W2CwZviUiiMca2L3Gwc312rg3sXZ+dawPf1aeXEkqpIjQYlFJFlOdgWGB1ASWwc312rg3sXZ+dawMf1Vdu+xiUUv5TnlsMSik/0WBQShWhwaCUKsK2wSAiU0Rkn4icE5EkEelbwvb9XdudE5G9InKnXeoTkatFZLWIpInIbyKyUURG2qG2Qvv1EZFcEUn2V22lqU9EQkXkCdc+WSJyUETusUltE0Rkq4hkikiqiCwRkUg/1NVPRD4WkRQRMSJysxf7dBKRr0TkrGu/v4mIeHVCY4ztPoBrgRzgDiAaeBU4A0R52L4lkOHaLtq1Xw4w1ib1zQIeBi4B2gCP4ZwVq6/VtbntdxGwF+ekvcl2+dq69vkA2IRzsp8WwKXAAKtrA3q7vo73ub4HewDfAV/4obZhwNPAOCATuLmE7WvhnEltOdDRtd9vwP1enc9f3wBl/E/YCLxeaNlu4BkP2/8T2F1o2RuAww71eTjGJuBFu9Tm+uF7DPi7n4PhQr+2g4F0oL4/v+dKWdsDwIFCy24Bzvi5zjNeBMNdwGmgutuyR4EUXKOR5/uw3aWE23T1haefL8109XEiUsUG9RWnJvCrr+qC0tfmestYQ+ApX9ZTzHlKU99oYDMwQ0QOi8huEXlFRMJtUNu3QCMRGSFO9YHrcL5syWo9gfXGmLNuy+JxzrzWoqSdbRcMnH+6ek/XbpEeti+Yrt6XSlPfH4jIVKApsNi3pV14bSLSCWdLYaIxJs/H9RRWmv+7VjjfZNYFGAtMA64EFlpdmzHGgTMI3gaygTRAgEk+rq00PP1MFKw7LzsGQ4UmImOB54EJ5n9T41lVS1VgGfCAMWaflbWcRxBgcP5/bTTGxOMMh7EiUngm8oASkRic/RBP4mxtXInzh+41K+vyBVu8V6IQu09XX5r6ABCRccAi4CZjzCc+rqs0tTXC2cn2loi85VoW5CxVcnHO61m4aR3I+sD5cqIUY0y627IfXH9GUfS3YiBrewTYZIx53vX5NhHJANaLyExjzGEf1VYann4mCtadl+1aDMbm09WXsj5E5Bqclw43G2Pe82VNZagtBegEXOz2MR/Y4/q7x39PgOoD53V840J9Cu1cf/qsxVXK2sJwhom7gs+t/tlyAH1FxP0Nz4NwTsy8v8S9/d3TW8pe12txXrPdjvM32iycPbHNXesXAYvcti8YrnzZtf3trv39OVx5IfVdh3MY7F6cTc2Cj7pW11bM/n/H/8OVF/J/Fw4cAlYAHXAOESYDK2xQ282ur+tdOPtCeuPsKE3yQ23h/C+8M4G/uf4e5Vr/DG7DpEBtnC2DpTiHK6/GOUpRfocrXf+wKTiTLQtnkvdzW7cOWFdo+/44x5CzgH3AnXapz/W5KeZjndW1FbOvX4OhlF/b9jhHBzJxtnLmADVtUtvdwA5XbUdxdkQ29UNdAzx8Dy10rV8I7C+0Tyfga+Ccq7bH8GKo0hijT1cqpYqy+jpIKWVDGgxKqSI0GJRSRWgwKKWK0GBQShWhwaCUKkKDQSlVhAaDUqqI/w+3BhoKWeGxGwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.1386271808999082,\n",
       " 'total_area': 0.1386271808999082}"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k25_d4\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_d{d}SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k25_d4, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN with k=55"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k55_d4 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=25\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k55_d4.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.1665039281705949,\n",
       " 'total_area': 0.1665039281705949}"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k55_d4\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_d{d}SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k55_d4, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=90"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k90_d4 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=90\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k90_d4.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.23763621059075604,\n",
       " 'total_area': 0.23763621059075604}"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k90_d4\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_d{d}SYMM.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k90_d4, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ProNE-kNN with d=2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=2\n",
    "# FOR KNN PRONE ONLY"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k5_d2 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=5\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k5_d2.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.10660595857565562,\n",
       " 'total_area': 0.10660595857565562}"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k5_d2\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_SYMM_d{d}.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k5_d2, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=25"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k25_d2 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=25\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k25_d2.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQYAAAD8CAYAAACVSwr3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAAsTAAALEwEAmpwYAAAoWUlEQVR4nO3daXgUZdr28f8VSAIxCLKGgAm7JmwCAWRHBXEQGBYVYVRAGWQRfd3m0RlHx317XFiMsjjygCCMyzg4ogF1ECSdhMQABhCRVVaDkZ2QkL7fD91xmiykSbq7qpPrdxwckK6qrlNJTqruqr5LjDEopZSnEKsDKKXsR4tBKVWMFoNSqhgtBqVUMVoMSqliqlsdoKj69eubZs2aWR1DqUotIyPjiDGmQWnLbVcMzZo1Iz093eoYSlVqIrLnQsv1VEIpVYwWg1KqGC0GpVQxWgxKqWK0GJRSxXhVDCLSV0SWi8h+ETEiMt6LbdqLyNcicsa93eMiIhVOrJTyO2+PGCKBLOA+4ExZK4vIpcAq4DDQ1b3dw8AD5YuplAokr4rBGLPCGPNnY8wHgNOLTf4ARADjjDFZ7u1eBB7Qowal/CNxXSIrt6/0yXv5a4yhB7DWGON5dJEERAPNiq4sIpNEJF1E0rOzs/0USanK6/vvv2dW8ixWbrV3MUThOo3wdNhj2XmMMXONMQnGmIQGDUq9S1MpVYqwBmHkSR5dYrr45P30qoRSQWzjxo2cOnWKzdmbAejQuINP3tdfn5U4BDQq8lojj2VKqQpyOBysXLmSXr168V317wirFkbr+q198t7+OmJwAH1EpIbHawOBA8BuP+1TqSqjsBTi4+O55ppryDqcRVyDOMKqhfnk/b29jyFSRK4Skavc28S4v45xL39eRL702GQJcBpYICLtRGQk8AjwqtHZZ5WqEM9SGDlyJBIibD68mXaN2vlsH94eMSQAme5fNYEn3X9+yr28MdCycGVjzDFcRwjRQDrwBvAK8KpPUitVReXn55ORkfFbKVSrVo3dv+7mZN5J2ke199l+vBpjMMasBkq9/8AYM76E174D+pY3mFLqfMYYQkNDmTBhAjVq1KBatWoAfHfoOwCfFoNelVAqCDgcDj766COcTieXXHLJb6UAkHU4i/Dq4bSq18pn+9NiUMrmCscUnE4nJQ3RbTq0ifgG8VQP8d1FRi0GpWys6ECj55ECwI+//EjG/gx6xPbw6X61GJSyqdTU1AuWAsAsxyxqhtZkQucJPt23FoNSNhUVFUXHjh1LLYUfjvzAp99/yh2d7qBuRF2f7tt2s0QrVdUdOnSIqKgoYmNjiY2NPW+Z0ziZmzaXrMNZ/PjLj0SERjCx60SfZ9AjBqVsJCUlhTlz5rB9+/Ziy5zGyV9X/ZWX177M1uytADzc92Euq3mZz3PoEYNSNpGSkkJSUhLx8fG0aNHivGUHjh/gha9f4NNtnzKl+xQe7P0g/pzaRItBKRvwLIWiYwoz1s3gzdQ3Abi/1/1Mu3qaX0sBtBiUstzBgwdLLYWtP29lpmMmN7S+gb9c8xeiL40OSCYtBqUs1rhxY8aMGUPLli2LXX2YkTyDWuG1eG7Qc9SuUTtgmXTwUSmLpKWlsXfvXgDatGlTrBQ2H97Mqh9XcWeXOwNaCqDFoJQlUlJS+Oyzz8jMzCx1nVmOWVwafikTuvj25iVvaDEoFWCeA41DhgwpcZ0TZ0+weudqbm5/M7XCawU4oRaDUgF1oasPnpL3JpPvzOe6ltcFOKGLFoNSAWKMYd++fWWWAsDqnauJDIukc3TnACb8L70qoVQA5OfnExoaysiRIzHGXLAUjDGs2bWGPs36EFotNIAp/0uPGJTyM4fDwdy5czl9+jQhISEXLAWAbUe2cejkIfo37x+QfCXRYlDKjwrnU2jYsCHh4eFebbN652oA+ja3bmZELQal/KSsSVZK88WOL2jbsC0NIxv6OWHptBiU8oMNGzaUqxTS96WTeSCTYXHD/JzwwnTwUSk/aNWqFT179uTaa6/1uhQAXk9+nfoR9fnDVX/wY7qy6RGDUj60bds2CgoKiIyMZODAgRdVCmk/peHY6+DubndTM7SmH1OWTYtBKR9xOBwsXbqU9evXl2v715Nfp8ElDRjbcayPk108LQalfMBzoLFr164Xv/1eB6k/pTK5+2RqhNYoewM/02JQqoLKe/WhkDGGGckzaBTZiDEdxvgp5cXRYlCqAk6ePMnXX39d7lIA1+ci1u9bz+Rukwmv7t29Dv6mVyWUqoDIyEjuuusu6tatW65SAEhMSSQqMorRHUb7OF35eX3EICJTRWSXiOSKSIaI9Clj/bEiskFETovIIRF5V0SiKh5ZKes5HA6Sk5MBaNCgQblLIed0Dqk/pXJL+1tsc7QAXhaDiIwGZgDPAZ2AZOAzEYkpZf1ewCLg/4C2wHAgHlhc8chKWatwTGH//v0lPkvyYqzdvRaD4ZoW1/gonW94e8TwALDAGDPPGLPVGDMdOAhMKWX9HsA+Y8xrxphdxpgUYBbQveKRlbJO0YHGis7WvHrXaurWrEu7qHY+SugbZRaDiIQBXYCVRRatBHqWstk6oLGIDBWX+sCtwIqKhFXKSikpKRW6+lBUgbOANbvW0Ld5X0LEXtcBvElTH6gGHC7y+mGgxDEDY4wDVxEsBvKAbECAcSWtLyKTRCRdRNKzs7O9jK5UYFWrVs1npQCux9cfzT1K/xb9Kx7Ox/xSUyISj+vU4WlcRxs34CqROSWtb4yZa4xJMMYkNGjQwB+RlCq348ePA9C1a1duuukmn5QCuD5eHSIh9Im94Di+JbwphiNAAdCoyOuNgEOlbPMokGaMedkYs8kYkwRMBW4XkablTqtUgDkcDmbPns2hQ65vdV89ASqvII8VP6zgqsZXUadmHZ+8py+VWQzGmDwgAxhYZNFAXFcnShKBq0w8FX5tr5MppUpRONDYqlUrfH0km5iSyM6cnUzqNsmn7+sr3t7g9CqwSETScA0sTgaigbcARGQhgDHmDvf6nwDzRGQKkAQ0Bl4HvjXG7PVZeqX8pLAU4uLiGDVqlM9OHwCyDmeRmJLI8PjhDGxV9N9be/CqGIwxy0SkHvAYrh/yLGCwMWaPe5WYIusvEJFawD3AK8Ax4Cvgf3wVXCl/2b59u19KITc/l6XfLeXNlDepF1GPx6993Cfv6w9S0Rs0fC0hIcGkp6dbHUNVYU6nk/T0dLp06eLTI4Vx74/jmz3f0L1pd/5yzV9o26itz977YolIhjEmobTler6vlFtmZibHjx8nJCSEbt26+bQUTuWdInlvMnd1uYslty6xtBS8ocWgFK4xheXLl//2+Qdf23hoI07jpGdsafcE2osWg6ryPAcaBw70z2Bg5gHXw2s7RXfyy/v7mhaDqtL8efXBU+aBTFrVbRXwx9mXlxaDqrLOnTvHxo0b/V4KxhgyD2TSuYk1z6EsD52oRVVJxhiqV6/OuHHjCAsL81spAOz6dRdHc48GzWkE6BGDqoIcDgfLli2joKCAmjVr+rUUAL7d/y2AZU+uLg8tBlWlFI4p+LsMPH178FsuDb+UFnVbBGyfFaXFoKqMis7mXB7nnOdYt3sdnaI72W7OhQsJnqRKVUBaWlrASwHg4y0fs+/4Pls8ROZi6OCjqhKaNm1Kp06duPHGGwNWCvkF+cx2zKZdo3Zc1/K6gOzTV/SIQVVq+/fvByA6Opphw4YFdGzhn1v+yU/HfuK+nvf5bB6HQNFiUJWWw+Fg/vz5bN26NeD73vrzVl5a8xIdojrYbgZob2gxqErJc6CxTZs2Ad335sObuf392wmvFs5rN74WdEcLoGMMqhKy4uoDwP5j+5mdMpuPNn9Eg0sasHj0YmLrxAZk376mxaAqlZ9//tmSUjh65ig3LbmJo7lHGdtxLFO6T6FhZMOA7NsftBhUpdKwYUNuv/12YmNjAzrQ+PR/nibnTA4fjP2A9lHtA7Zff9ExBlUppKamsmPHDgBatGgR0FJYuX0lH2/5mGlXT6sUpQBaDKoScDgcfP7552zatCng+y5wFvDsf54lrkEcU7qX9sTG4KPFoIKa50DjsGHDAr7/NbvXsO/4PqZePZXQaqEB37+/aDGooGXV1QdPSzcupV5EPQa0GhDwffuTFoMKSsYYsrOzLS2FA8cP8NXOr7il/S2EVQsL+P79Sa9KqKCTl5dHWFgYQ4cOxel0WlIKAO9/9z7GGEa3H23J/v1JjxhUUElJSeHNN9/kxIkTiIhlpXAm/wxLNi6hT7M+XF7ncksy+JMWgwoaKSkpJCUlER0dTUREhKVZFm9YzJHTR5h29TRLc/iLFoMKCoWlYOWYQqHTeaeZkzaHXrG9SGha6sOcgpoWg7K9TZs22aYUAN7d8C45Z3K4r+d9lubwJx18VLbXunVr+vTpQ79+/SwvhYMnDvJGyhv0bdaXLk26WJrFn/SIQdnW1q1bOXfuHDVr1uTaa6+1vBSMMTya9ChO4+TJAU9amsXfvC4GEZkqIrtEJFdEMkSkTxnrh4nIU+5tzorIXhG5t+KRVVXgcDj4xz/+QUpKitVRfrN001LW7l7L//T9H2LqxFgdx6+8OpUQkdHADGAq8I37989EJN4Ys7eUzZYCTYFJwHagEVCzwolVped5R2OPHj2sjgO4Pij15JdP0iu2F2OvCq6JXcvD2zGGB4AFxph57q+ni8gNwBTg0aIri8j1wHVAS2PMEffLuyuYVVUBdrjNuaiV21cy/ZPptGvUjjeGvRFU08CXV5n/hSISBnQBVhZZtBIo7Znew4H1wAMisk9EtovITBGJLGUfk0QkXUTSs7OzvU+vKpXTp0+zdu1aW5XC3qN7eXDFg7Rr1I4FNy2gVngtqyMFhDdHDPWBasDhIq8fBkr75EgLoDdwFhgF1AFmAdHATUVXNsbMBeYCJCQkGC8yqUooIiKCiRMnUrt2bVuUgtM4eeTzRwiREGYNnVVlSgH8d7kyBDDAWGPMMQARuQdIEpFGxpiiJaOqMIfDwdmzZ+nfvz9169a1Og5pP6WRcSCD3b/uJnVfKi8MeoHoS6OtjhVQ3hTDEaAA1+Chp0bAoVK2OQjsLywFt8I5vGMofvShqijPMQWn00lIiLXn72fPnWXa8mnknMkBYMiVQ7ipXbGD3EqvzGIwxuSJSAYwEHjfY9FA4MNSNlsH3CwikcaYk+7XCufw3lPesKpyKTrQaHUpACRtTyLnTA7zR86nZ0xPwquHWx3JEt7+TbwKjBeRiSISJyIzcI0XvAUgIgtFZKHH+kuAX4B3RKStiPTCdbnzA2PMzz7Mr4JUSkqK7a4+ALy38T1iasfQr3m/KlsK4OUYgzFmmYjUAx4DGgNZwGBjTOG//jFF1j8pIgNwDTiuB34FPgYe8VFuFeQiIiJo27YtI0aMsE0p/PjLj6TtS+NPff5UJS5JXojXg4/GmEQgsZRl/Ut4bRtwfbmTqUrp6NGj1KlThw4dOtC+fXtbPaVp8YbFhIaEMqrdKKujWK5q16IKKIfDwezZs3970KydSuG9je+xMHMhw+OHU/+S+lbHsZwWgwqIwoHGK664gqioKKvjnGfJhiU8tuox+jfvX+k/HOUtLQbld3a8zbnQosxF/PWLv3Jti2tJ/H1ilR5w9KTzMSi/2rlzp61KITc/l/ez3mfHLzs4kXeCj7d8zICWA5g5dKaWggctBuVXzZs3Z+jQoXTs2NHyUli+dTnP/udZjpw+Qu0atQmREIbHD+f5Qc9XuunfK0qLQflFRkYGzZs3p27dunTu3NnqOGz5eQsPf/Yw7Rq1Y9bQWXS7vJvVkWxNxxiUzzkcDv7973/bZpKVvII8Hv7sYS6reRnzR87XUvCCHjEon/IcaBw0aJDVcQBITEnk++zvmTN8DpfVvMzqOEFBjxiUz9jx6kP2qWzmrZ/HkCuHVLrnS/qTFoPyiYKCArZs2WKrUgCYkzaH/IJ87u91v9VRgoqeSqgKK3x+5G233Ub16tVtUwqHTx5m8YbFjGg7gmaXNbM6TlDRIwZVIQ6Hg3fffZf8/HzCw8NtUwo5p3N46suncBpnpX2MnD9pMahyKxxTqFGjhi3mUij03sb36DevH0nbk5jSfUqln+rdH/RUQpVLYSnExcUxatQo2xwpnMw7yfOrnye+YTzPDHyG1vVbWx0pKNmn5lXQWL9+vS1LAWD5luWcyj/Fo/0f1VKoAD1iUBctNjaWzp07M3jwYFuVgjGGJRuXENcgjo5RHa2OE9T0iEF5be/evRhjaNiwIUOHDrVVKQBsPLSRrdlbGdtxrK3meghGWgzKKw6Hg3feeYesrCyro5TowPEDvLL2FSJCIxgaN9TqOEFPTyVUmTzvaIyPj7c6znn2HdvHm6lv8mGWa8LyP/X9U5V6MIy/aDGoC7Lbbc7GGGYmzyR5bzIFpoDvDn1HiIRwS/tbmNx9cpV7MIy/aDGoUv3yyy+sWrXKNqXgNE6e+OIJlmxcQseojkSERXDbVbcxsetEGtdqbGm2ykaLQZWqXr16jBs3jqZNm1peCrtydvHy2pdJ2p7E3d3u5uE+D+sAox9pMahiUlJSqFOnDldeeSWxsbFWxyExJZHX1r1GWLUwHurzEJO7TdZS8DMtBnWewjGF9u3bc+WVV1odh2O5x5idMpt+zfvxwqAXdGr3ANHLleo3ngONv//9762OA8BHmz/i7LmzPND7AS2FANJiUID9rj6A6wrEexvfo2NUR+Ib2usyaWWnxaAAOHbsmK1KAWD9vvXsyNnB2I5jrY5S5egYQxWXm5tLjRo1GDRoEMYYW318esG3C6gVXosbr7zR6ihVjtffBSIyVUR2iUiuiGSISB8vt+stIudExJ730lZhDoeDxMREjh07hojYqhRWbl9J0vYk7uxyJzVDa1odp8rx6jtBREYDM4DngE5AMvCZiFxwBgwRuQxYCHxZwZzKxwrHFC6//HIiIyOtjnOenNM5PLbqMeIbxjO5+2Sr41RJ3v4T8QCwwBgzzxiz1RgzHTgITClju7eB/wMcFciofMyOA42enl39LMdzj/PSDS/pE6IsUmYxiEgY0AVYWWTRSqDnBbabCjQCnqlIQOVbWVlZti6FH478wL+2/IsJXSYQ1zDO6jhVljeDj/WBasDhIq8fBkqcqF9E2gNPAFcbYwrKuktNRCYBkwBiYnR+Pn9q06YN/fv3p3fv3rYrBYBZybOICI1gUrdJVkep0nw+2iQi4cAy4CFjzC5vtjHGzDXGJBhjEho0aODrSArXkUJeXh5hYWH069fPlqWwLXsbK35Ywbgu4/SJURbzphiOAAW4Tgs8NQIOlbB+YyAOeMd9NeIc8DjQ1v319RUJrC6ew+Hgww8/xOGw91DPzOSZRIZFcleXu6yOUuWVWQzGmDwgAxhYZNFAXFcnitoPtAeu8vj1FvCj+88lbaP8xHOgsXfv3lbHKdWWn7fw+fbPGd95PHVq1rE6TpXn7Q1OrwKLRCQNWAdMBqJx/cAjIgsBjDF3GGPygfPuWRCRn4Gzxhi9lyGA7H71wdPM5JnUCq/FnQl3Wh1F4WUxGGOWiUg94DFcpwpZwGBjzB73KjpiaDO5ubkkJycHRSlkHc5i1Y+ruK/nfdSuUdvqOAoQY4zVGc6TkJBg0tPTrY5RKRw7dozIyEhbl4IxhgkfTmDjwY2smbRG52sMEBHJMMYklLbcPvfAKp9ISUkhKSkJYwy1a9e2dSkAfJD1AWt3r+X/9fp/Wgo2osVQiRSWwvHjx7HbkWBJDhw/wDP/eYbul3fn9k63Wx1HedBiqCQKS6FwTMFOH4gqycm8k9z773sxxvDioBcJEXvnrWr0Y9eVQNFSsPvpw4mzJ5jw4QQ2HdzErKGzuLzO5VZHUkVoMVQCtWvXpl27dgwfPtz2peA0TqYtn8Z3h75j1tBZDGozyOpIqgRaDEEsJyeHunXrEhcXR1xccHzgaPGGxazbs46nBz6tpWBjemIXpBwOB2+88QZ79+61OorX9hzdw4tfv0ifZn0Y02GM1XHUBegRQxDyvKOxSZMmVscp09lzZ/kg6wMSUxOpXq06zw96Xp8LYXNaDEEmmG5zPnvuLMs2LWNO2hwOnTxE5+jOPNr/UX2cXBDQYggie/bsCZpSKHAWMP6D8aTtSyOhSQIv/e4lesb01COFIKHFEERiYmIYMWIEbdu2tXUpgGuG57R9aTw98GnGdBijhRBkdPAxCKSnp5OdnY2I0KFDB9uXwo5fdvC/a/+XAS0HaCkEKS0Gm3M4HHz66aekpqZaHcUrR04dYdryaUSERvDM9c9oKQQpPZWwMc+Bxt/97ndWxynV6bzTHDhxgDP5Z3hoxUPsP76f+SPn0+ASnaYvWGkx2FQwXH04cfYEC75dwDsZ73As9xgAEaER/H3U3+l2eTeL06mK0GKwIafTyfbt221bCsdzj/9WCMfPHue6ltcx5MohhEgIbRu1pfllza2OqCpIi8FmCgoKqFatGmPGjCEkJMRWpXA89zhvp7/Ngm8XcDLvJANbDeSeHvfQrlE7q6MpH9NisBGHw8GWLVu47bbbCA8PtzrOeYwxTP54Mqn7UhnUehD39LhHH01fiWkx2ITnmEL16vb7a0nem0zqvlQev/ZxxnUeZ3Uc5Wd6udIG7D7QaIzhtXWv0bhWY27tcKvVcVQAaDFYLCMjw9alALB291oyD2QytftUwqvb6xRH+Yf9jlmrmObNm9O1a1cGDRpku1I4fPIwc9Pm8t6m92hyaRNuan+T1ZFUgGgxWGTnzp00b96cunXrMnjwYKvjnOfQiUPMSZvD0k1LKXAWMDx+ONN7TNdH0lchWgwWKBxTGDp0KJ07d7Y6zm8OnjjInNQ5LPtuGU7jZET8CKZcPYXYOrFWR1MBpsUQYIWlEBcXR8eOHa2OA7imcX8r9S3ez3ofp3Eyqt0opnSbopO0VmFaDAHkWQqjRo2yfExh37F9vJn6Jh9mfQjAze1vZnK3yTSpbf9ZoZR/aTEEyNGjR/nyyy9tUQoHjh9glmMWH23+iBAJYXSH0dzd7W6iL422LJOyFy2GAKlTpw4TJkwgKirK0lLY8csO/vCPP3As9xhjOo7h7m5361RrqhgtBj9LSUkhIiKCDh06WDZx68ETB8k8kEleQR7Pr34eg+Fft/+LNvXbWJJH2Z/XNziJyFQR2SUiuSKSISJ9LrDuSBFZKSLZInJCRFJFZJhvIgcPh8NBUlISP/zwg2XPkiz8jMP0T6bz4IoHERGWjF6ipaAuyKsjBhEZDcwApgLfuH//TETijTElPdigH/AV8BiQA/wB+KeI9DfGrPVJcpvzHGgcMWKEZTMZfbHjC7IOZ/Hn/n+mT7M+RF8aTWRYpCVZVPAQb/4lE5FUYJMx5o8er20HPjDGPOrVjkTSgLXGmAcvtF5CQoJJT0/35i1tyy5XH5zGybCFwzidf5qVd66keoieOSoXEckwxiSUtrzMUwkRCQO6ACuLLFoJ9LyILLWAX0vZxyQRSReR9Ozs7It4S3vKzc21vBQAVm1fxdbsrUzvMV1LQV0Ub75b6gPVgMNFXj8MDPBmJyIyDWgKLCppuTFmLjAXXEcM3rynHZ0+fZqIiAj69++PMcbSR9GfyjvF818/T4u6LRgaN9SyHCo4+f07V0RGAS8DY40xe/y9P6sUPksyJycHEbG0FABeWvMS+47t47nrn9OjBXXRvPnuPQIUAI2KvN4IOHShDUXkJlxHCXcYYz4pV8IgUDim0KxZM2rXrm11HJL3JvPuhneZ0GUCXZt2tTqOCkJlFoMxJg/IAAYWWTQQSC5tOxG5BVcpjDfGfFCRkHZmt0lWnMbJU18+RWydWB7o/YClWVTw8vYY81VgkfvKwjpgMhANvAUgIgsBjDF3uL++FVcpPASsEZEo9/vkGWNyfBffWlu2bLFVKQCs2LaC7b9sZ8aQGdQMrWl1HBWkvCoGY8wyEamH676ExkAWMNhjzCCmyCaT3e/9uvtXoa+B/uWPay9t2rThuuuuo0ePHrYohQJnATOTZ9K6XmsGX2GvOR5UcPF6VMoYkwgklrKs/4W+rmw2bdpE69atqVmzJr1797Y6DuC6w3HppqXsyNnB7KGzCRGdtU+Vnw5XX6TCMYU+ffpw7bXXWh0HYwzr9qxjpmMmGfsz6BjVkUFtBlkdSwU5LYaL4DnQ2K9fP0uzGGNYu3stMx0zyTyQSVStKP523d+4pf0terSgKkyLwUt2uvqQeSCTZ/7zDBsObqBxrcY8PeBpRrUbpTM4K5/RYvBCXl4eaWlptiiF5L3J/PGjP3JZzct4ZuAzjGo3SidpVT6nxVAGYwxhYWHceeedREREBLwUjDF8tfMrMg9kkl+Qz6INi4itE8uimxdR/5L6Ac2iqg4thgtwOBxkZ2czdOhQatWqFZB9Oo2TL3d8SeaBTIwxfLPnG7b8vIUQCSFEQmjfqD1zRsyhXkS9gORRVZMWQyk8xxSMMX6dT2Hz4c0s37ocg+sKw/fZ31M9pDohEkJM7Rhe/t3LDIsbpp95UAGj32klKDrQ6M8PROWczmHChxM4lnuM0JBQmtZuyiuDX2HIlUO0CJRl9DuviNTU1IBeffjbl3/jeO5xPr7tY+Iaxvl1X0p5S4uhiPr169OhQweGDRvm11I45zzHosxFfLrtU+7vdb+WgrIVLQa37OxsGjRoQMuWLWnZsqXf9nPOeY7lW5fzRsob7P51N90v787k7pP9tj+lykNvkcM1xXtiYiI7d+70634cex0M/PtAHv7sYSJCI0j8fSLv3vKujiUo26ny35EpKSkkJSURHx9PbKz/Ht565NQRpn8yndo1avPW8LcY0HKAZTNHK1WWKl0MnqXgz4FGYwyPrXqMU3mnWHrrUlrVa+WX/SjlK1W2GPbv3+/3Uli9czWffP8JJ8+e5IsdX/BIv0e0FFRQqLLF0KRJE26++WauuOIKv5TCv7//Nw98+gC1a9QmMiyS4fHDubPLnT7fj1L+UOWKYf369TRp0oTo6Gji4+N9/v65+bks2rCIl9a8RJcmXZg/cr4++UkFnSp1VSIlJYUVK1bgryddfbbtM/rP788LX79A32Z9eXvk21oKKihVmSMGz4HGG2+80efv/8/N/+RPn/+Jdo3aMWPIDLpf3t3n+1AqUKpEMfjj6sOpvFMs3rCY9P3pnHOeY82uNVwdczXzRszT2ZlV0Kv0xWCMYdeuXT4theVbl/PUV0/x65lfaV2vNWHVwhgeP5ynBz6tpaAqhUpdDOfOnaN69ercfPPNiIhPSuH9797n0aRH6RTdiXkj5tEpupMPkiplL5V28NHhcPD2229z5swZqlev7pNSWLZpGY8kPULvZr1ZdPMiLQVVaVXKYiicT6Fu3bqEhflmPsT3Nr7Hn1f+mb7N+jJn+BxqhNbwyfsqZUeV7lTC17M5/3rmV+atn8ectDlc0+Ia3hj2hs7GrCq9SlUMmZmZF1UKH23+iGWblmEwJS43xrAtexun8k8xIn4Ez17/rJaCqhIqVTG0bNmSq6++mgEDBpRZCu9mvssTXz5B63qtaXBJg1LXG9RmEBMTJnJFgyt8HVcp26oUxfDjjz/SokULLr30UgYNKvvxbAu/XciTXz3JgJYDmDl0ph4FKFWE14OPIjJVRHaJSK6IZIhInzLW7+deL1dEdoqIX6YpcjgcLF68mIyMDK/WfyfjHVcptBrArGGztBSUKoFXRwwiMhqYAUwFvnH//pmIxBtj9pawfnNgBfB34DagN5AoItnGmA99Fd5zoLFz587Fli/ZuISlG5f+NobgNE6+z/6eQa0HMWPIDEKrhfoqilKVihhT8sDbeSuJpAKbjDF/9HhtO/CBMebREtZ/ERhpjGnt8dp8oK0xpseF9pWQkGC8+ZBTWVcf3k5/m+dWP0fbRm1pHNn4t9db1mvJ/b3u11JQVZqIZBhjEkpbXuYRg4iEAV2A/y2yaCXQs5TNeriXe0oCxolIqDEmv6z9XsjstbN5x/EOYXXCSD6RzNsL3z5vudM42ZGzg8FtBvPqja9qCSh1kbw5lagPVAMOF3n9MDCglG2igC9KWL+6+/0Oei4QkUnAJICYmJgyAzWp24ROzToRHh5e6ryJN7S5gXt73qsTrSpVDrb4qTHGzAXmgutUoqz1R7QdwYi2I/yeS6mqypurEkeAAqBRkdcbAYdK2eZQKeufc7+fUsrGyiwGY0wekAEMLLJoIJBcymaOUtZPr+j4glLK/7y9j+FVYLyITBSROBGZAUQDbwGIyEIRWeix/ltAExF53b3+RGA8xQcwlVI25NUYgzFmmYjUAx4DGgNZwGBjzB73KjFF1t8lIoOB14ApwAHgXl/ew6CU8h+vBx+NMYlAYinL+pfw2tdA8buOlFK2VynnY1BKVYwWg1KqGC0GpVQxXn1WIpBEJBvYU+aKrjso7XxPhJ3z2Tkb2DufnbOB9/lijTGlTkRiu2LwloikX+hDIFazcz47ZwN757NzNvBdPj2VUEoVo8WglCommIthrtUBymDnfHbOBvbOZ+ds4KN8QTvGoJTyn2A+YlBK+YkWg1KqGC0GpVQxti0Gu05XX558IjJSRFaKSLaInBCRVBEZZodsRbbrLSLnRCTLX9nKk09EwkTkKfc2Z0Vkr4jca5NsY0Vkg4icFpFDIvKuiET5IVdfEVkuIvtFxIjIeC+2aS8iX4vIGfd2j0tpcyEWZYyx3S9gNJAP/BGIA2YBJ4GYUtZvDpxyrxfn3i4fGGWTfDOAR4BuQCvgCVyzYvWxOpvHdpcBO3FN2ptll79b9zYfAWm4JvtpBnQH+ludDejl/nu83/09eDXwLfClH7INBp4DbgJOA+PLWP9SXDOp/QNo597uBPCgV/vz1zdABf8npALziry2HXi+lPVfBLYXeW0+4LBDvlLeIw14xS7Z3D98TwB/83MxXOzf7fXAMaC+P7/nypntIWBPkdcmACf9nPOkF8UwBTgO1PR47TFgP+6rkRf6ZbtTCY/p6otOP1+e6eoTRMSnc8eXM19JagG/+ioXlD+biEzFNSfnM77MU8J+ypNvOLAeeEBE9onIdhGZKSKRNsi2DmgsIkPFpT5wK66HLVmtB7DWGHPG47UkXDOvNStrY9sVAxeerr60c7eoUtYvnK7el8qT7zwiMg1oCizybbSLzyYi7XEdKdxmjCnwcZ6iyvP/rgWuJ5l1BEYB9wA3AAuszmaMceAqgsVAHpANCDDOx9nKo7SficJlF2THYqjURGQU8DIw1vx3ajyrsoQDy4CHjDG7rMxyASGAwfX/K9UYk4SrHEaJSNGZyANKROJxjUM8jeto4wZcP3RzrMzlC7Z4rkQRdp+uvjz5ABCRm4CFwB3GmE98nKs82RrjGmR7R0Tecb8W4ooq53DN61n00DqQ+cD1cKL9xphjHq9tdf8eQ/F/FQOZ7VEgzRjzsvvrTSJyClgrIn82xuzzUbbyKO1nonDZBdnuiMHYfLr6cuZDRG7Bdeow3hjzgS8zVSDbfqA9cJXHr7eAH91/LvW/J0D5wHUeH11kTKGN+3efHXGVM1sErjLxVPi11T9bDqCPiNTweG0gromZd5e5tb9Hess56joa1znbRFz/os3ANRIb616+EFjosX7h5crX3etPdG/vz8uVF5PvVlyXwe7DdahZ+Kuu1dlK2P5v+P9y5cX8v4sEfgLeB9riukSYBbxvg2zj3X+vU3CNhfTCNVCa4Ydskfy3vE8Dj7v/HONe/jwel0mB2riODJbiulw5EtdViuC9XOn+D5uKq9nO4mryvh7LVgOri6zfD9c15LPALmCyXfK5vzYl/FptdbYStvVrMZTz7/YKXFcHTuM6ynkDqGWTbNOBze5sB3ENRDb1Q67+pXwPLXAvXwDsLrJNe2ANkOvO9gReXKo0xuinK5VSxVl9HqSUsiEtBqVUMVoMSqlitBiUUsVoMSilitFiUEoVo8WglCpGi0EpVcz/B8E/F0jnJageAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.14650443832262017,\n",
       " 'total_area': 0.14650443832262017}"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k25_d2\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_SYMM_d{d}.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k25_d2, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=55"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k55_d2 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=55\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k55_d2.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.2064761248852158,\n",
       " 'total_area': 0.2064761248852158}"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k55_d2\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_SYMM_d{d}.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k55_d2, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### ProNE-kNN k=90"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# for each of the true draws from the model, create a bootstrap and perform a test with Q permutations\n",
    "random.seed(100)\n",
    "np.random.seed(100)\n",
    "\n",
    "p_vals_prone_k90_d2 = []\n",
    "A_boots_list = []\n",
    "\n",
    "k=90\n",
    "Q=1000 # number of sims to do in the paired exch test\n",
    "\n",
    "for m in A_true_draws:\n",
    "    _, A_boots = create_single_kNN_prone_bootstrap(m, d=d, Q=Q, n_neighbors=k) \n",
    "\n",
    "    # embed the observed and bootstrapped matrix together\n",
    "    yhat_est = UASE([m, A_boots], d=d)\n",
    "    # do a test between the obs and the bootstrap, get a p-value ---------------------------------\n",
    "    p_val = test_temporal_displacement_two_times(yhat_est, n=m.shape[0], n_sim=Q) \n",
    "\n",
    "    p_vals_prone_k90_d2.append(p_val)\n",
    "    A_boots_list.append(A_boots[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "{'area_above': 0.0,\n",
       " 'area_below': 0.21180338740944804,\n",
       " 'total_area': 0.21180338740944804}"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_hat_list = p_vals_prone_k90_d2\n",
    "roc = []\n",
    "alphas = []\n",
    "for alpha in np.linspace(0, 1, 100):\n",
    "    alphas.append(alpha)\n",
    "    num_below_alpha = sum(p_hat_list < alpha)\n",
    "    roc_point = num_below_alpha / len(p_hat_list)\n",
    "    roc.append(roc_point)\n",
    "\n",
    "# Get the power at the 5% significance level\n",
    "power_significance = 0.05\n",
    "power_idx = alphas.index(min(alphas, key=lambda x: abs(x - power_significance)))\n",
    "power = roc[power_idx]\n",
    "\n",
    "\n",
    "plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "_ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "plt.xticks(fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "\n",
    "# plt.savefig(f\"figs/SBM_knnProneResample_k{k}_M{M}_SYMM_d{d}.png\")\n",
    "plt.show()\n",
    "\n",
    "compute_roc_and_areas(p_vals_prone_k90_d2, significance_level=0.05)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### all on one plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "# # Function to plot ROC curves\n",
    "# def plot_roc(ax, indices, title):\n",
    "#     for i in indices:\n",
    "#         p_hat_list = p_list_allnames[i]\n",
    "#         roc = []\n",
    "#         alphas = []\n",
    "#         for alpha in np.linspace(0, 1, 100):\n",
    "#             alphas.append(alpha)\n",
    "#             num_below_alpha = sum(p_hat_list < alpha)\n",
    "#             roc_point = num_below_alpha / len(p_hat_list)\n",
    "#             roc.append(roc_point)\n",
    "\n",
    "#         score = np.round(compute_roc_and_areas(p_hat_list, significance_level=0.05)['total_area'], 3)\n",
    "\n",
    "#         ax.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "#         ax.plot(alphas, roc, color=colors[i], label=(labels[i]) + \",  $S=$\" + str(score))\n",
    "\n",
    "#     ax.tick_params(axis='both', which='major', labelsize=15)\n",
    "#     ax.set_aspect('equal', adjustable='box')\n",
    "#     ax.legend(loc=\"upper left\", bbox_to_anchor=(0, 1), fontsize=10)\n",
    "#     ax.set_title(title, fontsize=16)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1296x720 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_list_allnames = [p_vals_k5, p_vals_k25,p_vals_k55, p_vals_k90, \n",
    "                   p_vals_YYT, p_vals_ESWR, \n",
    "                   p_vals_prone_k5_d2, p_vals_prone_k25_d2, p_vals_prone_k55_d2, p_vals_prone_k90_d2,\n",
    "                   p_vals_prone_k5_d4, p_vals_prone_k25_d4,p_vals_prone_k55_d4, p_vals_prone_k90_d4] #p_vals_ESWR_plusRand\n",
    "colors = ['#FF5733', '#40E0D0', '#3357FF', '#FF33A6', '#A633FF', '#FFAC1C', 'g', '#FF6347', '#6A5ACD', '#DC143C', '#00FA9A', '#FF8C00', '#4682B4', '#8B4513']  \n",
    "labels = ['ASE-kNN $k=5$', 'ASE-kNN $k=25$', 'ASE-kNN $k=55$', 'ASE-kNN $k=90$', 'ASE-$YY^T$', 'ASE-ESWR', 'ProNE-kNN $k=5$', 'ProNE-kNN $k=25$','ProNE-kNN $k=55$', 'ProNE-kNN $k=90$', \n",
    "          'ProNE-kNN $k=5$', 'ProNE-kNN $k=25$', 'ProNE-kNN $k=55$','ProNE-kNN $k=90$']\n",
    "\n",
    "fig, axs = plt.subplots(1, 4, figsize=(18,10))\n",
    "\n",
    "# Define the indices for each panel\n",
    "ase_knn_indices = [0, 1, 2, 3]\n",
    "prone_knn_indices_d2 = [6, 7, 8, 9]\n",
    "prone_knn_indices_d4 = [10, 11, 12, 13]\n",
    "other_indices = [4, 5]\n",
    "\n",
    "# Plot ASE-kNN\n",
    "plot_roc(axs[0], ase_knn_indices, \"ASE-kNN (d=4)\")\n",
    "\n",
    "# Plot ProNE-kNN\n",
    "plot_roc(axs[1], prone_knn_indices_d2, \"ProNE-kNN (d=2)\")\n",
    "\n",
    "# Plot ProNE-kNN d=3\n",
    "plot_roc(axs[2], prone_knn_indices_d4, \"ProNE-kNN (d=4)\")\n",
    "\n",
    "# Plot other methods\n",
    "plot_roc(axs[3], other_indices, \"Other Methods (d=4)\")\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f\"SBM_allMethods_M{M}_SYMM_3plots_different_d.png\", facecolor=\"white\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "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
}
