{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "a155ea46",
   "metadata": {},
   "source": [
    "# MomentNet Dataset Generator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47fdc8d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "from GraphTools.utils import simulate_graphs_sorted, general_graphon\n",
    "import numpy as np\n",
    "\n",
    "# Ensure dataset folder exists\n",
    "os.makedirs('dataset', exist_ok=True)\n",
    "\n",
    "# Generate graphs for each graphon\n",
    "for graphon_idx in range(13):\n",
    "    if graphon_idx == 11:\n",
    "        sbm_split = [0.5, 0.5]\n",
    "        sbm_param = np.array([[0, 0.8], [0.8, 0]])\n",
    "        graphon = general_graphon(graphon_idx, sbm_split, sbm_param)\n",
    "    elif graphon_idx == 12:\n",
    "        sbm_split = [0.5, 0.5]\n",
    "        sbm_param = np.array([[0.8, 0], [0, 0.8]])\n",
    "        graphon = general_graphon(graphon_idx, sbm_split, sbm_param)\n",
    "    else:\n",
    "        graphon = general_graphon(graphon_idx, None, None)\n",
    "\n",
    "    # Generate 10 sets of 10 graphs\n",
    "    all_graphs = []\n",
    "    for set_idx in range(10):\n",
    "        graphs = simulate_graphs_sorted(graphon, num_graphs=10, graph_size='vary')\n",
    "        all_graphs.append(graphs)\n",
    "        \n",
    "    # Save all graphs for this graphon index to dataset folder\n",
    "    file_path = f'dataset/graphon_{graphon_idx}.pkl'\n",
    "    with open(file_path, 'wb') as f:\n",
    "        pickle.dump(all_graphs, f)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27d5f684",
   "metadata": {},
   "source": [
    "# MomentNet Scalability Dataset Generator\n",
    "## Graphon 5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e815f6e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "import pickle\n",
    "from GraphTools.utils import simulate_graphs, general_graphon\n",
    "import numpy as np\n",
    "\n",
    "Wxy = general_graphon(5, [0.5, 0.5], np.array([[0, 0.0], [0.0, 0]]))\n",
    "\n",
    "# Loop over node sizes from 50 to 1000 with step size 50\n",
    "for num_nodes in range(10, 1201, 20):\n",
    "    # Generate 10 graphs for the current node size\n",
    "    graphs = simulate_graphs(Wxy, num_graphs=10, num_nodes=num_nodes, graph_size='fixed', seed_edge=num_nodes)\n",
    "    \n",
    "    # Save the entire list of graphs to one file\n",
    "    filename = f\"dataset/scalability/graphs_{num_nodes}_single.gpickle\"\n",
    "    with open(filename, \"wb\") as f:\n",
    "        pickle.dump(graphs, f)\n",
    "    print(f\"Saved 10 graphs with {num_nodes} nodes in {filename}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70a4a91a",
   "metadata": {},
   "source": [
    "## Graphon 12 $(0.5 + 0.1cos(\\pi v)cos(\\pi u))$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af8816ec",
   "metadata": {},
   "outputs": [],
   "source": [
    "import networkx as nx\n",
    "import pickle\n",
    "from GraphTools.utils import simulate_graphs, general_graphon\n",
    "import numpy as np\n",
    "\n",
    "Wxy = general_graphon(12, [0.5, 0.5], np.array([[0, 0.0], [0.0, 0]]))\n",
    "\n",
    "# Loop over node sizes from 50 to 1000 with step size 50\n",
    "for num_nodes in range(10, 1201, 20):\n",
    "    # Generate 10 graphs for the current node size\n",
    "    graphs = simulate_graphs(Wxy, num_graphs=10, num_nodes=num_nodes, graph_size='fixed', seed_edge=num_nodes)\n",
    "    \n",
    "    # Save the entire list of graphs to one file\n",
    "    filename = f\"dataset/scalability_12/graphs_{num_nodes}_single.gpickle\"\n",
    "    with open(filename, \"wb\") as f:\n",
    "        pickle.dump(graphs, f)\n",
    "    print(f\"Saved 10 graphs with {num_nodes} nodes in {filename}\")"
   ]
  }
 ],
 "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.12.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
