{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 559
        },
        "id": "JcwENthwtKq9",
        "outputId": "977961d5-dc59-4410-857e-1a8d1ab60b4d"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Using device: cuda\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "T=16: 100%|██████████| 4/4 [00:02<00:00,  1.76it/s]\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 700x500 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAArIAAAHqCAYAAAD4TK2HAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAb7RJREFUeJzt3Xd4FOXax/HvbEISUkkCobcjIIReQhEQERBQwV5RQQQVEVEExQZiP9iRiIoKCHjkiIJiAREBpSNITbAgAkoJkJBCEkKy8/4xLznGEEjZzWR3f5/ryiU7Ozt7j8nec2fyPPdjmKZpIiIiIiLiYRx2ByAiIiIiUhoqZEVERETEI6mQFRERERGPpEJWRERERDySClkRERER8UgqZEVERETEI6mQFRERERGPpEJWRERERDySClkRERER8UgqZEVE5IyGDBnCRRddZNvrAfbv309QUBCrV68u03Hs9tZbb1GvXj1OnjxpdygiXkWFrIiU2cyZMzEMA8MwWLVqVaHnTdOkbt26GIbB5ZdfXuC5068zDAN/f3+ioqJo3749o0ePJiEhodCx/vjjjwKv+efXCy+8kL/vRRddVOC5qKgo4uLieP/993E6na7/HwEkJiZiGAZBQUEcP37cLe9RHBkZGUycOJF+/foRFRWFYRjMnDnzrK9ZtGgRDoeDQ4cOFbnPk08+edb//2d7bWk89dRTdOrUia5du7JixYqzvvffv8ri4MGDjB8/np49exIWFoZhGKxYsaLI/XNycnjuuedo2rQpQUFBVK9encsuu4w///wzf58hQ4aQk5PD22+/XabYRKQgf7sDEBHvERQUxIcffki3bt0KbF+5ciV//vkngYGBZ3xdnz59uO222zBNk9TUVLZu3cqsWbN48803+fe//82YMWMKveamm27i0ksvLbS9bdu2BR7XqVOH559/HoAjR47wwQcfcMcdd/DLL78UKHr/buzYsbz88svnPN9rrrmG+fPnF9g2Z84cAgICOHnyJPPnz2fYsGHnPI47HD16lKeeeop69erRunXrsxZip3355Ze0b9+eGjVqnHPfadOmERoaWmh7lSpVShHtmR05coRZs2Yxa9YsAJo1a8bs2bML7PPII48QGhrKY4895rL3/fnnn/n3v/9N48aNadmyJWvXri1y31OnTnHZZZexZs0ahg8fTqtWrUhJSWH9+vWk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\n"
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "log–log slope (ideal ≈ –1): -1.048   R²=0.999\n"
          ]
        }
      ],
      "source": [
        "# EXP3-MDEP Verification\n",
        "\n",
        "!pip install -q torch numpy matplotlib tqdm scipy\n",
        "\n",
        "import torch, math, random, gc\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "from tqdm import tqdm\n",
        "from scipy import stats\n",
        "\n",
        "# ---- Environment and random seeds ----\n",
        "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
        "torch.manual_seed(0)\n",
        "np.random.seed(0)\n",
        "random.seed(0)\n",
        "print(\"Using device:\", device)\n",
        "\n",
        "# ==== 1) Generate SBM Boolean adjacency matrix ====\n",
        "def gen_sbm_bool(n, k=3, p_intra=0.3, p_inter=0.05):\n",
        "    \"\"\"\n",
        "    Return an n×n torch.bool adjacency matrix (no self-loops, undirected).\n",
        "    Community sizes are as even as possible.\n",
        "    \"\"\"\n",
        "    sizes = [n // k] * k\n",
        "    for i in range(n % k):\n",
        "        sizes[i] += 1\n",
        "    probs = torch.full((n, n), p_inter, device=device)\n",
        "    offset = 0\n",
        "    for sz in sizes:\n",
        "        probs[offset:offset+sz, offset:offset+sz] = p_intra\n",
        "        offset += sz\n",
        "    # Sample upper triangle\n",
        "    M = (torch.rand((n, n), device=device) < probs)\n",
        "    A = torch.triu(M, diagonal=1)\n",
        "    # Make symmetric\n",
        "    A = A | A.T\n",
        "    return A\n",
        "\n",
        "# ==== 2) Bernoulli forward edge flips (boolean) ====\n",
        "@torch.no_grad()\n",
        "def flip_edges_bool(A, beta):\n",
        "    \"\"\"\n",
        "    A: bool matrix\n",
        "    Return next adjacency matrix and number of flips.\n",
        "    \"\"\"\n",
        "    n = A.size(0)\n",
        "    N = (torch.rand((n, n), device=device) < beta)\n",
        "    N = torch.triu(N, 1) | torch.triu(N, 1).T\n",
        "    A_next = A ^ N\n",
        "    flips = int(N.triu(1).sum().item())\n",
        "    return A_next, flips\n",
        "\n",
        "# ==== 3) Conditional / unconditional targets (see Appendix B) ====\n",
        "@torch.no_grad()\n",
        "def R_cond_bool(A, beta, p0):\n",
        "    \"\"\"\n",
        "    Compute conditional target R for boolean matrix A.\n",
        "    beta, p0 are scalars.\n",
        "    \"\"\"\n",
        "    num1 = (1.0 - beta) * p0\n",
        "    den1 = num1 + beta * (1.0 - p0)\n",
        "    num0 = beta * p0\n",
        "    den0 = num0 + (1.0 - beta) * (1.0 - p0)\n",
        "    Af = A.float()\n",
        "    R = torch.where(Af > 0.5, num1/den1, num0/den0)\n",
        "    R.fill_diagonal_(0.0)\n",
        "    return R  # float32 matrix\n",
        "\n",
        "@torch.no_grad()\n",
        "def R_uncond_bool(A, flips, E, p0):\n",
        "    \"\"\"\n",
        "    Use Beta posterior mean in place of Monte Carlo:\n",
        "    Posterior Beta(flips+1, E-flips+1) mean = (flips+1)/(E+2)\n",
        "    \"\"\"\n",
        "    beta_hat = (flips + 1) / (E + 2)\n",
        "    return R_cond_bool(A, beta_hat, p0)\n",
        "\n",
        "# ==== 4) Compute sum of Δ_i for a single graph ====\n",
        "def one_mdep_run(n, T, beta):\n",
        "    \"\"\"\n",
        "    Generate forward sequence A0...AT and flips_list,\n",
        "    then accumulate sum of Δ_i = ||R_cond - R_uncond||_F^2 / E.\n",
        "    \"\"\"\n",
        "    A = gen_sbm_bool(n)\n",
        "    E = n * (n - 1) // 2\n",
        "    # True graph density p0\n",
        "    p0 = A.triu(1).float().mean().item()\n",
        "    A_list = [A]\n",
        "    flips_list = []\n",
        "    for _ in range(T):\n",
        "        A, f = flip_edges_bool(A, beta)\n",
        "        A_list.append(A)\n",
        "        flips_list.append(f)\n",
        "\n",
        "    gap = 0.0\n",
        "    for At, f in zip(A_list[1:], flips_list):\n",
        "        R_c = R_cond_bool(At, beta, p0)\n",
        "        R_u = R_uncond_bool(At, f, E, p0)\n",
        "        gap += torch.sum((R_c - R_u)**2).item() / E\n",
        "    return gap\n",
        "\n",
        "# ==== 5) Multi-scale statistics and regression ====\n",
        "def run_mdep(T=8, beta=0.1, sizes=[400,800,1600,3200], trials=20):\n",
        "    \"\"\"\n",
        "    For each graph size, run trials and record mean and SEM of Δ sum.\n",
        "    \"\"\"\n",
        "    res = {'E': [], 'gap': [], 'sem': []}\n",
        "    for n in tqdm(sizes, desc=f\"T={T}\"):\n",
        "        E = n * (n - 1) // 2\n",
        "        tmp = []\n",
        "        for _ in range(trials):\n",
        "            g = one_mdep_run(n, T, beta)\n",
        "            tmp.append(g)\n",
        "            # Clear small tensors\n",
        "            torch.cuda.empty_cache()\n",
        "        arr = np.array(tmp, dtype=float)\n",
        "        res['E'].append(E)\n",
        "        res['gap'].append(arr.mean())\n",
        "        res['sem'].append(arr.std(ddof=1) / math.sqrt(trials))\n",
        "        gc.collect()\n",
        "        torch.cuda.empty_cache()\n",
        "    return res\n",
        "\n",
        "def plot_mdep(res, T):\n",
        "    \"\"\"\n",
        "    Plot sum Δ_i vs E on log–log scale and show regression slope.\n",
        "    \"\"\"\n",
        "    E = np.array(res['E'])\n",
        "    gap = np.array(res['gap'])\n",
        "    sem = np.array(res['sem'])\n",
        "    plt.figure(figsize=(7,5))\n",
        "    plt.errorbar(E, gap, yerr=sem, fmt='o', capsize=3, label='data')\n",
        "    a, b, r, _, _ = stats.linregress(np.log(E), np.log(gap))\n",
        "    plt.plot(E, np.exp(b) * E**a, 'r-', label=f'slope={a:.2f}')\n",
        "    plt.xscale('log')\n",
        "    plt.yscale('log')\n",
        "    plt.xlabel('|E|')\n",
        "    plt.ylabel('sum Δᵢ (ℓ₂ per edge)')\n",
        "    plt.title(f'MDEP ∑Δᵢ ∝ 1/|E|  (T={T})')\n",
        "    plt.legend()\n",
        "    plt.grid(ls='--', alpha=0.3)\n",
        "    plt.tight_layout()\n",
        "    plt.show()\n",
        "    print(f\"log–log slope (ideal ≈ –1): {a:.3f}   R²={r**2:.3f}\")\n",
        "\n",
        "# ==== 6) Main entry point ====\n",
        "if __name__ == \"__main__\":\n",
        "    T = 16\n",
        "    res = run_mdep(T=T, beta=0.1,\n",
        "                   sizes=[400,800,1600,3200], trials=20)\n",
        "    plot_mdep(res, T)\n",
        "    gc.collect()\n",
        "    torch.cuda.empty_cache()"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "machine_shape": "hm",
      "provenance": [],
      "gpuType": "L4"
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU"
  },
  "nbformat": 4,
  "nbformat_minor": 0
}