{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9a6a691c-873f-4763-916d-79a368ae6b08",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Synthetic multilayer graph saved to synthetic_multilayer_graph.npy\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "def generate_correlated_multilayer_graph(n_nodes=100, n_layers=3, edge_prob=0.1, inter_layer_corr=0.2, save_path='synthetic_multilayer_graph.npy', seed=42):\n",
    "    \"\"\"\n",
    "    生成带有层间相关性的多层图邻接张量\n",
    "    :param n_nodes: 节点数量\n",
    "    :param n_layers: 图层数量\n",
    "    :param edge_prob: 每层边的概率\n",
    "    :param inter_layer_corr: 图层间的边相关性（0=no corr, 1=完全相关）\n",
    "    :param save_path: 保存的npy文件名\n",
    "    :param seed: 随机种子\n",
    "    \"\"\"\n",
    "    np.random.seed(seed)\n",
    "    A = np.zeros((n_nodes, n_nodes, n_layers), dtype=np.float32)\n",
    "    \n",
    "    # 生成基础概率矩阵（用于相关性建模）\n",
    "    base_edge_prob = np.random.rand(n_nodes, n_nodes)\n",
    "    base_edge_prob = np.triu(base_edge_prob, 1)\n",
    "    base_edge_prob = base_edge_prob + base_edge_prob.T\n",
    "    # 保证对称性\n",
    "    \n",
    "    for m in range(n_layers):\n",
    "        # 对每一层引入相关性\n",
    "        noise = np.random.randn(n_nodes, n_nodes) * np.sqrt(1 - inter_layer_corr)\n",
    "        noise = np.triu(noise, 1)\n",
    "        noise = noise + noise.T\n",
    "        correlated_prob = inter_layer_corr * base_edge_prob + (1 - inter_layer_corr) * np.random.rand(n_nodes, n_nodes)\n",
    "        layer_edges = (correlated_prob < edge_prob).astype(np.float32)\n",
    "        # 去除自环（对角线为0）\n",
    "        np.fill_diagonal(layer_edges, 0)\n",
    "        A[:, :, m] = layer_edges\n",
    "\n",
    "    # 保证对称性\n",
    "    for m in range(n_layers):\n",
    "        A[:, :, m] = np.triu(A[:, :, m], 1)\n",
    "        A[:, :, m] = A[:, :, m] + A[:, :, m].T\n",
    "\n",
    "    np.save(save_path, A)\n",
    "    print(f\"Synthetic multilayer graph saved to {save_path}\")\n",
    "\n",
    "if __name__ == '__main__':\n",
    "    generate_correlated_multilayer_graph()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1e1b89b-d499-48d9-bf2b-e7f563b8b818",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
