{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "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\n",
    "from scipy.integrate import simps\n",
    "from matplotlib.patches import Ellipse"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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_list.append(np.array([[0.8, 0.1, 0.5, 0.3],\n",
    "                        [0.4, 0.6, 0.9, 0.2],\n",
    "                        [0.7, 0.2, 0.4, 0.8],\n",
    "                        [0.3, 0.5, 0.6, 0.1]]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generate adjacency matrix from the B matrix\n",
    "As = np.zeros((n, n))\n",
    "P_list = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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",
    "# 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",
    "As = As.astype(int)\n",
    "P = np.column_stack(P_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Generate more samples from the same model with the same parameters (P matrix)\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",
    "    # 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",
    "    As = As.astype(float)\n",
    "\n",
    "    A_true_draws.append(As)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "d=4"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Go through all values of $k$ and calculate the area between the curve and the diagonal from the ROC curve plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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_values = []\n",
    "scores = []\n",
    "\n",
    "for k in range(2,500):\n",
    "\n",
    "    p_vals = []\n",
    "    A_boots_list = []\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.append(p_val)\n",
    "        A_boots_list.append(A_boots)\n",
    "\n",
    "    # Provided code\n",
    "    p_hat_list = p_vals\n",
    "    roc = []\n",
    "    alphas = []\n",
    "\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",
    "    plt.plot(np.linspace(0, 1, 2), np.linspace(0, 1, 2), linestyle=\"--\", c=\"grey\")\n",
    "    _ = plt.plot(alphas, roc, color='#228B22')\n",
    "\n",
    "    # Set title and aspect ratio\n",
    "    plt.title(f\"ROC Curve for 4 Community \\n SBM with n={n} nodes, k={k}\")\n",
    "    plt.gca().set_aspect('equal', adjustable='box')\n",
    "\n",
    "    plt.show()\n",
    "\n",
    "    # Calculate the area between ROC and y=x line\n",
    "\n",
    "    def compute_area_above_below_curve(x, y):\n",
    "        area_above = 0.0\n",
    "        area_below = 0.0\n",
    "        \n",
    "        for i in range(1, len(x)):\n",
    "            x0, x1 = x[i - 1], x[i]\n",
    "            y0, y1 = y[i - 1], y[i]\n",
    "            line0, line1 = x0, x1  # Since line y = x\n",
    "            \n",
    "            if y1 == y0:  # Vertical segment\n",
    "                if y0 > x0:\n",
    "                    area_above += (y0 - x0) * (x1 - x0)\n",
    "                else:\n",
    "                    area_below += (x0 - y0) * (x1 - x0)\n",
    "                continue\n",
    "            \n",
    "            # Find intersection with y = x\n",
    "            if (y0 >= x0 and y1 >= x1) or (y0 <= x0 and y1 <= x1):\n",
    "                if y0 >= x0 and y1 >= x1:\n",
    "                    area_above += 0.5 * (y0 + y1 - x0 - x1) * (x1 - x0)\n",
    "                else:\n",
    "                    area_below += 0.5 * (x0 + x1 - y0 - y1) * (x1 - x0)\n",
    "            else:\n",
    "                x_intersect = x0 + (x0 - y0) * (x1 - x0) / (y1 - y0)\n",
    "                if y0 < x0:\n",
    "                    area_below += 0.5 * (x0 - y0) * (x_intersect - x0)\n",
    "                    area_above += 0.5 * (y1 - x1) * (x1 - x_intersect)\n",
    "                else:\n",
    "                    area_above += 0.5 * (y0 - x0) * (x_intersect - x0)\n",
    "                    area_below += 0.5 * (x1 - y1) * (x1 - x_intersect)\n",
    "        \n",
    "        return area_above, area_below\n",
    "\n",
    "    x = np.linspace(0, 1, 100)\n",
    "    roc_interpolated = np.interp(x, alphas, roc)\n",
    "\n",
    "    # Compute areas\n",
    "    area_above, area_below = compute_area_above_below_curve(x, roc_interpolated)\n",
    "    total_area = area_above + area_below\n",
    "\n",
    "    print(f\"Area above the y=x line: {area_above} for k={k}\")\n",
    "    print(f\"Area below the y=x line: {area_below} for k={k}\")\n",
    "    print(f\"Total area (above and below y=x): {total_area} for k={k}\")\n",
    "\n",
    "    # add to lists\n",
    "    k_values.append(k)\n",
    "    scores.append(total_area)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# put scores and x_labels into a dataframe\n",
    "df = pd.DataFrame({\"alpha\": x_labels, \"score\": scores})"
   ]
  },
  {
   "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"
    }
   ],
   "source": [
    "# plot the scores for each k\n",
    "plt.plot(k_values[0:499], scores[0:499])\n",
    "plt.xlabel(\"k\")\n",
    "plt.ylabel(\"Total area between ROC curve and y=x line\")\n",
    "plt.title(\"Total area between ROC curve and y=x line for \\n different k values between 2 and 500\")\n",
    "#white space\n",
    "plt.tight_layout()\n",
    "# white background\n",
    "plt.gca().set_facecolor('white')\n",
    "# plt.savefig(\"4commSBM_k_scores_2_500_SYMM.png\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
