{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "5c9151be",
   "metadata": {},
   "source": [
    "# RSA Minimization plot"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "576973ca",
   "metadata": {},
   "source": [
    "The following script replicates the figure 2 with the RSA for differents reduction matrices and a coarsening ratio ranging from 0.05 to 0.85.\n",
    "\n",
    "\n",
    "\n",
    "The script is quite long to compute and takes 1h30 for each Laplacian on CPU and around 45 minutes on GPU."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcae3b34",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "import torch\n",
    "\n",
    "from utils.data_utils import load_graph, Config\n",
    "from utils.utils_plot import rsa_minimization\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e70fbfb7",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_common_coarsening = Config()\n",
    "config_common_coarsening.max_levels = 100000\n",
    "config_common_coarsening.max_level_r = 0.9999\n",
    "config_common_coarsening.delete_diagonal = True\n",
    "config_common_coarsening.space_preserved = \"eigenvectors\"\n",
    "config_common_coarsening.method_cost = \"Spectral_np\"\n",
    "config_common_coarsening.R_already_computed = \"No\"\n",
    "config_common_coarsening.method = 'edges'\n",
    "config_common_coarsening.normalized_cost = False\n",
    "config_common_coarsening.K = 100\n",
    "config_common_coarsening.n_e_percent = 0.1\n",
    "config_common_coarsening.r = 0.5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "284e98a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "cora = load_graph('Cora')\n",
    "\n",
    "r_list = np.round(np.arange(0.05, 0.87, 0.05), 2).tolist()\n",
    "print(r_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d2cac7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "rsa_loukas_list, rsa_mp_list, rsa_opt_list, rsa_support_list, rsa_optim_g_list, rsa_optim_g_sparse_list =  rsa_minimization(\n",
    "    original_graph=cora, config=config_common_coarsening, laplacian_kind=\"normalized_self_loop\", r_list=r_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "180b3a3b",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "plt.plot(r_list, rsa_loukas_list, label=r'$P_{Loukas}$')\n",
    "plt.plot(r_list, rsa_mp_list, label=r'$P_{MP}$')\n",
    "plt.plot(r_list, rsa_opt_list, label=r'$P_{opt}$')\n",
    "plt.plot(r_list, rsa_support_list, label=r'$P^{*}_{Q^{\\top}}$')\n",
    "plt.plot(r_list, rsa_optim_g_list, label=r'$P^{*}_{g}$')\n",
    "plt.plot(r_list, rsa_optim_g_sparse_list, label=r'$P^{*}_{g,l_1}$')\n",
    "\n",
    "plt.xlabel(\"r\")\n",
    "plt.ylabel(\"RSA\")\n",
    "plt.title(\"RSA Cora Normalized Laplacian\")\n",
    "plt.legend(fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e658a5f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "rsa_loukas_list_combi, rsa_mp_list_combi, rsa_opt_list_combi, rsa_support_list_combi, rsa_optim_g_list_combi, rsa_optim_g_sparse_list_combi = rsa_minimization(\n",
    "    original_graph=cora, config=config_common_coarsening, laplacian_kind=\"combinatorial\", r_list=r_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f51207f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(r_list, rsa_loukas_list_combi, label=r'$P_{Loukas}$')\n",
    "plt.plot(r_list, rsa_mp_list_combi, label=r'$P_{MP}$')\n",
    "plt.plot(r_list, rsa_opt_list_combi, label=r'$P_{opt}$')\n",
    "plt.plot(r_list, rsa_support_list_combi, label=r'$P^{*}_{Q^{\\top}}$')\n",
    "plt.plot(r_list, rsa_optim_g_list_combi, label=r'$P^{*}_{g}$')\n",
    "plt.plot(r_list, rsa_optim_g_sparse_list_combi, label=r'$P^{*}_{g,l_1}$')\n",
    "plt.xlabel(\"r\")\n",
    "plt.title(\"RSA Cora Combinatorial Laplacian\")\n",
    "plt.ylabel(\"RSA\")\n",
    "plt.legend(fontsize=14)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5db0a0ca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b9e757a8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "80a3b778",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rennes_test2",
   "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.22"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
