{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "ac921498",
   "metadata": {},
   "source": [
    "# GNNs training"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b7b7e1fb",
   "metadata": {},
   "source": [
    "The following script replicates the results presented in Tab.1\n",
    "\n",
    "The script takes 15 minutes by graph on GPU but it is very long on CPU due to the dense Propagation of P_{opt}."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "494f14ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils.data_utils import load_graph, Config\n",
    "from utils.utils_plot import training_exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcc7e613",
   "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.laplacian_norm = \"normalized_self_loop\"\n",
    "config_common_coarsening.laplacian_preserved = \"normalized_self_loop\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1f0d634f",
   "metadata": {},
   "outputs": [],
   "source": [
    "r_list = [0.3,0.5,0.7]\n",
    "cora = load_graph('Cora')\n",
    "citeseer = load_graph('CiteSeer')\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72af10b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_SGC_cora, results_gcn_cora = training_exp(original_graph= cora, config_coarsening=config_common_coarsening, r_list=r_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fe6f8284",
   "metadata": {},
   "outputs": [],
   "source": [
    "P_list_name = [\"Loukas\", \"MP\", \"Opt\", \"support\" , \"optim_g\", \"optim_g_sparse\"]\n",
    "for P_name in P_list_name:\n",
    "    print(P_name)\n",
    "    print(f\"Results for {P_name} on Cora dataset:\")\n",
    "    for r in r_list:\n",
    "        print(f\"r = {r}, accuracy = {results_SGC_cora[P_name][r]['acc']}, std = {results_SGC_cora[P_name][r]['std']}\")\n",
    "    print(\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dca4a348",
   "metadata": {},
   "outputs": [],
   "source": [
    "for P_name in P_list_name:\n",
    "    print(f\"Results for {P_name} on GCN Cora\")\n",
    "    for r in r_list:\n",
    "        print(f\"r = {r}, accuracy = {results_gcn_cora[P_name][r]['acc']}, std = {results_gcn_cora[P_name][r]['std']}\")\n",
    "    print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc04d4fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_SGC_citeseer, results_gcn_citeseer = training_exp(original_graph= citeseer, config_coarsening=config_common_coarsening, r_list=r_list)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0bf4e61",
   "metadata": {},
   "outputs": [],
   "source": [
    "for P_name in P_list_name:\n",
    "    print(f\"Results for {P_name} on SGC Citeseer\")\n",
    "    for r in r_list:\n",
    "        print(f\"r = {r}, accuracy = {results_SGC_citeseer[P_name][r]['acc']}, std = {results_SGC_citeseer[P_name][r]['std']}\")\n",
    "    print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1fcd535e",
   "metadata": {},
   "outputs": [],
   "source": [
    "for P_name in P_list_name:\n",
    "    print(f\"Results for {P_name} on GCN Citeseer\")\n",
    "    for r in r_list:\n",
    "        print(f\"r = {r}, accuracy = {results_gcn_citeseer[P_name][r]['acc']}, std = {results_gcn_citeseer[P_name][r]['std']}\")\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29bebb12",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91edf064",
   "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
}
