{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "machine_shape": "hm"
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 577
        },
        "id": "Z_NhuRQtra01",
        "outputId": "43e3f2a5-6bea-4fc9-8219-670d3f821ace"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=0.0: 100%|██████████| 10/10 [00:00<00:00, 24.61it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "γ=0.00  ReconErr=106275.98, Acc=0.969\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=0.3: 100%|██████████| 10/10 [00:00<00:00, 25.35it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "γ=0.30  ReconErr=104533.88, Acc=0.971\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=0.5: 100%|██████████| 10/10 [00:00<00:00, 23.13it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "γ=0.50  ReconErr=100642.58, Acc=0.980\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=0.7: 100%|██████████| 10/10 [00:00<00:00, 23.36it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "γ=0.70  ReconErr=93514.98, Acc=0.992\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=1.0: 100%|██████████| 10/10 [00:00<00:00, 29.68it/s]\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "γ=1.00  ReconErr=73881.78, Acc=0.998\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x400 with 2 Axes>"
            ],
            "image/png": "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vPrqq4/9XvJ4eHgwc+ZMpkyZwtKlS3nvvfe0+06cOMGFCxd4//33C308IYQoq9asWUPPnj0xMzOjX79+LF26lGPHjtG4cWNtm8L8VlCr1XTp0oXQ0FD69u3LmDFjSE1NZffu3Zw7dw4fHx+9s+Xk5BAcHEzLli359NNPqVChApB7gjsjI4MRI0ZQuXJljh49yuLFi4mKimLDhg3a1585c4ZWrVphamrK8OHD8fT05OrVq2zfvp25c+fy/PPP4+7uzpo1a/L1b2vWrMHHx4dmzZoVmK1Ro0Z4e3uzfv16Bg4cqLNv3bp12NnZERwcDMBbb73Fxo0bGTVqFAEBASQkJHDgwAEuXLhAgwYNCv19dOjQgTNnzjBr1ixeeuklGjZsqN23du1aNBrNE82CE6JQFCHKie+//14BlN9//125e/eucuvWLWXjxo1KlSpVFHNzc+XWrVvatu3atVNq166tZGZmardpNBqlefPmiq+vr3bbtGnTFEDZvHlzvvfTaDSKoijKwoULFUBZvXq1dt+DBw+UZs2aKdbW1kpKSoqiKIoSGRmpAErlypWVxMREbdtt27YpgLJ9+3ZFURTl3r17CqB88skn//l5a9asqbRp0+aR30PLli2VnJwcnX0DBw5UPDw88r1m+vTpysP/ubh8+bJiZGSk9OjRQ1Gr1QV+7v/K8McffyiA8scff2i/D0dHR6VWrVrK/fv3te127NihAMq0adN0MgLKrFmzdI5Zv359pWHDhvne69/atGmjAAU+3nzzzXyfuV+/fvmO4eHhoQDKzp07dbaPHTtWAZQ///xTuy01NVXx8vJSPD09td9V3uf39vZWMjIyHpt5165dOn8DeTp16qR4e3trn3fr1k2pWbPmY49XWL1791YaNWqks23MmDGKpaWl9u9WCCHKq+PHjyuAsnv3bkVRcvu/qlWrKmPGjNFpV5jfCt99950CKAsWLHhkm3/3nXnyfj98//332m15feXEiRPzHa+gfickJERRqVTKjRs3tNtat26t2NjY6Gx7OI+iKMqkSZMUc3NzJSkpSbstLi5OMTExUaZPn57vfR42adIkxdTUVOc3T1ZWllKpUiVlyJAh2m22trbKyJEj//NYhZWdna04Ozsr48eP19let25dpWXLlkXyHkIURKaXi3InKCiIKlWq4O7uTu/evbGysuKnn37STrFOTExk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OkepqamCtbW1MGXKFCEpKUnYv3+/YGdnJ3zwwQdivQSDq+gchYaGCtbW1sK3334rXLt2TTh06JDg5uYmvP3222K9BIPLzc0VYmJihJiYGAGAEBYWJsTExAg3btwQBEEQZs+eLYwYMUI7vuTSJDNmzBAuXbokbNiwgZcMM3Gsy/qxLuvHuqwf67J+rMv6mWJdZtNtotatWyc0adJEkMvlQufOnYU//vhDe9vLL78sBAcH64z//vvvhVatWglyuVxo27atcODAASMnNr6KzFHTpk0FAKW+QkNDjR/ciCr67+hxtaG4C0LF5+jUqVOCr6+voFAohObNmwtLly4ViouLjZzauCoyR0VFRcLChQsFNzc3QalUCi4uLsJ7770n3Lt3z/jBjeTXX38t8/dLybwEBwcLL7/8cqn7+Pj4CHK5XGjevLmwbds2o+emimFd1o91WT/WZf1Yl/VjXX42U6zLEkHgcQVEREREREREhsBzuomIiIiIiIgMhE03ERERERERkYGw6SYiIiIiIiIyEDbdRERERERERAbCppuIiIiIiIjIQNh0ExERERERERkIm24iIiIiIiIiA2HTTURERERERGQgbLqJiIiIiIiIDIRNNxEREREREZGBsOkmIiIiIiIiMhA23UQkqldffRXt2rVDWlqazvaRI0eib9++IqUiIiKqnViXiaoem24iEtU333wDKysrrFy5UrstOzsbe/bswdixY0VMRkREVPuwLhNVPTbdRCQqZ2dnzJgxA99//z00Gg0AYMeOHbC1tUXv3r1FTkdERFS7sC4TVT023UQkuoCAAOTm5uL3338HAGzZsgXBwcEwMzMTORkREVHtw7pMVLX4k0NEolMqlQgMDMSuXbtgZWWFmJgY7Nq1S+xYREREtRLrMlHVYtNNRCZh0KBBmDBhAtRqNbp164ZWrVqJHYmIiKjWYl0mqjoSQRAEsUMQEeXn56NRo0Z48OABtm7diuDgYLEjERER1Vqsy0RVh+d0E5FJUCqVePPNN1GnTh0MGjRI7DhERES1GusyUdVh001EJqN169Zo3rw5LC0txY5CRERU67EuE1UNNt1EREREREREBsKmm4iIiIiIiMhAuJAaERERERERkYFwTzcRERERERGRgbDpJiIiIiIiIjIQNt1EREREREREBsKmm4iIiIiIiMhA2HQTERERERERGQibbiIiIiIiIiIDYdNNREREREREZCBsuomIiIiIiIgMhE03ERERERERkYH8f49n9zAp1GsLAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ],
      "source": [
        "#couped factor γ analysis\n",
        "import numpy as np\n",
        "import networkx as nx\n",
        "import matplotlib.pyplot as plt\n",
        "from tqdm import tqdm\n",
        "\n",
        "def generate_sbm_graph(n, pin, pout, n_classes, seed=None):\n",
        "    if seed is not None:\n",
        "        np.random.seed(seed)\n",
        "    sizes = [n // n_classes] * n_classes\n",
        "    probs = np.full((n_classes, n_classes), pout)\n",
        "    np.fill_diagonal(probs, pin)\n",
        "    G = nx.stochastic_block_model(sizes, probs, seed=seed, directed=False)\n",
        "    A0 = nx.to_numpy_array(G, dtype=np.int8)\n",
        "    labels = np.repeat(np.arange(n_classes), sizes)\n",
        "    return A0, labels\n",
        "\n",
        "def coupled_noise_forward(A0, X0, beta, gamma, sigma_x, sigma_a, seed=None):\n",
        "    if seed is not None:\n",
        "        np.random.seed(seed)\n",
        "    n, d = X0.shape\n",
        "    eta = np.random.normal(0, 1, size=(n, d))\n",
        "    xi = np.random.normal(0, 1, size=A0.shape)\n",
        "    X_tilde = X0 + sigma_x * eta\n",
        "    flip_mask = np.random.rand(n, n) < beta\n",
        "    A_flip = np.logical_xor(A0, flip_mask).astype(np.int8)\n",
        "    shared = (eta[np.newaxis, :, :].mean(-1) + eta[:, np.newaxis, :].mean(-1)) / 2\n",
        "    A_tilde = A_flip + sigma_a * (gamma * shared + np.sqrt(1 - gamma**2) * xi)\n",
        "    return A_tilde, X_tilde\n",
        "\n",
        "def simple_denoise(A_tilde, X_tilde, thresh=0.5):\n",
        "    A_hat = (A_tilde > thresh).astype(np.int8)\n",
        "    X_hat = X_tilde\n",
        "    return A_hat, X_hat\n",
        "\n",
        "def reconstruction_error(A0, A_hat, X0, X_hat):\n",
        "    err_A = np.sum(np.abs(A0 - A_hat))\n",
        "    err_X = np.linalg.norm(X0 - X_hat)\n",
        "    return err_A + err_X\n",
        "\n",
        "def structure_based_classification_accuracy(A_hat, labels, n_classes):\n",
        "    # Predict label based on majority vote of neighbors' true labels\n",
        "    n = A_hat.shape[0]\n",
        "    preds = np.zeros(n, dtype=int)\n",
        "    for i in range(n):\n",
        "        neigh = np.where(A_hat[i] == 1)[0]\n",
        "        if len(neigh) == 0:\n",
        "            preds[i] = np.random.randint(n_classes)\n",
        "        else:\n",
        "            counts = np.bincount(labels[neigh], minlength=n_classes)\n",
        "            preds[i] = np.argmax(counts)\n",
        "    return np.mean(preds == labels)\n",
        "\n",
        "# Configuration\n",
        "config = {\n",
        "    'n': 600,\n",
        "    'pin': 0.3,\n",
        "    'pout': 0.05,\n",
        "    'n_classes': 3,\n",
        "    'd_feat': 3,\n",
        "    'beta': 0.2,\n",
        "    'sigma_x': 0.5,\n",
        "    'sigma_a': 0.5,\n",
        "    'thresh': 0.5,\n",
        "    'gamma_grid': [0.0, 0.3, 0.5, 0.7, 1.0],\n",
        "    'n_trials': 10,\n",
        "    'seed': 42,\n",
        "}\n",
        "\n",
        "# Run experiment\n",
        "A0, labels = generate_sbm_graph(config['n'], config['pin'], config['pout'], config['n_classes'], seed=config['seed'])\n",
        "X0 = np.eye(config['d_feat'])[labels]\n",
        "\n",
        "recon_err = []\n",
        "accs = []\n",
        "for gamma in config['gamma_grid']:\n",
        "    errs = []\n",
        "    acc_list = []\n",
        "    for trial in tqdm(range(config['n_trials']), desc=f\"γ={gamma}\"):\n",
        "        A_tilde, X_tilde = coupled_noise_forward(\n",
        "            A0, X0, config['beta'], gamma, config['sigma_x'], config['sigma_a'], seed=config['seed'] + trial\n",
        "        )\n",
        "        A_hat, X_hat = simple_denoise(A_tilde, X_tilde, thresh=config['thresh'])\n",
        "        errs.append(reconstruction_error(A0, A_hat, X0, X_hat))\n",
        "        acc_list.append(structure_based_classification_accuracy(A_hat, labels, config['n_classes']))\n",
        "    recon_err.append(np.mean(errs))\n",
        "    accs.append(np.mean(acc_list))\n",
        "    print(f\"γ={gamma:.2f}  ReconErr={recon_err[-1]:.2f}, Acc={accs[-1]:.3f}\")\n",
        "\n",
        "# Plot results\n",
        "plt.figure(figsize=(10,4))\n",
        "plt.subplot(1,2,1)\n",
        "plt.plot(config['gamma_grid'], recon_err, marker='o')\n",
        "plt.xlabel('γ'); plt.ylabel('Reconstruction Error'); plt.title('Reconstruction Error vs. γ')\n",
        "plt.subplot(1,2,2)\n",
        "plt.plot(config['gamma_grid'], accs, marker='o')\n",
        "plt.xlabel('γ'); plt.ylabel('Classification Accuracy'); plt.title('Accuracy vs. γ')\n",
        "plt.tight_layout()\n",
        "plt.show()\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# ===== Uncomment the next line if dependencies are missing =====\n",
        "# !pip install -q numpy scipy matplotlib networkx tqdm\n",
        "\n",
        "import numpy as np, networkx as nx, matplotlib.pyplot as plt\n",
        "from tqdm import tqdm\n",
        "import scipy.stats as stats\n",
        "import matplotlib as mpl\n",
        "from google.colab import files\n",
        "\n",
        "# ---------- Global plot style settings ----------\n",
        "mpl.rcParams.update({\n",
        "    \"font.family\": \"sans-serif\",\n",
        "    \"font.sans-serif\": [\"DejaVu Sans\", \"Arial\"],\n",
        "    \"axes.labelsize\": 10,\n",
        "    \"axes.titlesize\": 11,\n",
        "    \"legend.fontsize\": 9,\n",
        "    \"xtick.labelsize\": 9,\n",
        "    \"ytick.labelsize\": 9\n",
        "})\n",
        "\n",
        "# ---------- Experiment functions ----------\n",
        "def generate_sbm_graph(n, pin, pout, n_classes, seed=None):\n",
        "    \"\"\"\n",
        "    Generate a stochastic block model graph.\n",
        "    n: total nodes\n",
        "    pin: intra-community edge probability\n",
        "    pout: inter-community edge probability\n",
        "    n_classes: number of communities\n",
        "    seed: random seed\n",
        "    Returns adjacency matrix and node labels.\n",
        "    \"\"\"\n",
        "    if seed is not None:\n",
        "        np.random.seed(seed)\n",
        "    sizes = [n // n_classes] * n_classes\n",
        "    probs = np.full((n_classes, n_classes), pout, dtype=float)\n",
        "    np.fill_diagonal(probs, pin)\n",
        "    G = nx.stochastic_block_model(sizes, probs, seed=seed, directed=False)\n",
        "    A0 = nx.to_numpy_array(G, dtype=np.int8)\n",
        "    labels = np.repeat(np.arange(n_classes), sizes)\n",
        "    return A0, labels\n",
        "\n",
        "def coupled_noise_forward(A0, X0, beta, gamma, sigma_x, sigma_a, seed=None):\n",
        "    \"\"\"\n",
        "    Apply coupled structural and feature noise.\n",
        "    A0: original adjacency matrix\n",
        "    X0: original feature matrix\n",
        "    beta: edge flip probability\n",
        "    gamma: coupling coefficient\n",
        "    sigma_x: feature noise scale\n",
        "    sigma_a: adjacency noise scale\n",
        "    seed: random seed\n",
        "    Returns noisy adjacency and noisy features.\n",
        "    \"\"\"\n",
        "    if seed is not None:\n",
        "        np.random.seed(seed)\n",
        "    n, d = X0.shape\n",
        "    # Sample feature noise\n",
        "    eta = np.random.normal(0, 1, size=(n, d))\n",
        "    # Sample structural noise\n",
        "    xi  = np.random.normal(0, 1, size=A0.shape)\n",
        "    X_tilde = X0 + sigma_x * eta\n",
        "    flip_mask = np.random.rand(n, n) < beta\n",
        "    A_flip   = np.logical_xor(A0, flip_mask).astype(np.int8)\n",
        "    # Shared noise term based on feature noise averages\n",
        "    shared   = (eta[np.newaxis, :, :].mean(-1) +\n",
        "                eta[:, np.newaxis, :].mean(-1)) / 2\n",
        "    A_tilde  = A_flip + sigma_a * (gamma * shared +\n",
        "                                   np.sqrt(1 - gamma**2) * xi)\n",
        "    return A_tilde, X_tilde\n",
        "\n",
        "def simple_denoise(A_tilde, X_tilde, thresh=0.5):\n",
        "    \"\"\"\n",
        "    Perform simple threshold-based denoising.\n",
        "    Returns binary adjacency and denoised features.\n",
        "    \"\"\"\n",
        "    return (A_tilde > thresh).astype(np.int8), X_tilde\n",
        "\n",
        "def reconstruction_error(A0, A_hat, X0, X_hat):\n",
        "    \"\"\"\n",
        "    Compute total reconstruction error:\n",
        "    sum of absolute adjacency differences plus feature L2 norm.\n",
        "    \"\"\"\n",
        "    return np.sum(np.abs(A0 - A_hat)) + np.linalg.norm(X0 - X_hat)\n",
        "\n",
        "def structure_based_classification_accuracy(A_hat, labels, n_classes):\n",
        "    \"\"\"\n",
        "    Classify each node by majority vote over its neighbors' labels.\n",
        "    Returns classification accuracy.\n",
        "    \"\"\"\n",
        "    n = A_hat.shape[0]\n",
        "    preds = np.zeros(n, dtype=int)\n",
        "    for i in range(n):\n",
        "        neigh = np.where(A_hat[i] == 1)[0]\n",
        "        if len(neigh) == 0:\n",
        "            preds[i] = np.random.randint(n_classes)\n",
        "        else:\n",
        "            counts = np.bincount(labels[neigh], minlength=n_classes)\n",
        "            preds[i] = np.argmax(counts)\n",
        "    return np.mean(preds == labels)\n",
        "\n",
        "def ci95(arr):\n",
        "    \"\"\"\n",
        "    Compute mean and 95% confidence half-width for an array.\n",
        "    Returns (mean, half-width).\n",
        "    \"\"\"\n",
        "    arr = np.asarray(arr, dtype=float)\n",
        "    m   = arr.mean()\n",
        "    if len(arr) < 2:\n",
        "        return m, 0.0\n",
        "    h = stats.t.ppf(0.975, len(arr)-1) * stats.sem(arr)\n",
        "    return m, h\n",
        "\n",
        "# ---------- Experiment configuration ----------\n",
        "cfg = dict(\n",
        "    n=600, pin=0.3, pout=0.05, n_classes=3,\n",
        "    d_feat=3, beta=0.2, sigma_x=0.5, sigma_a=0.5, thresh=0.5,\n",
        "    gamma_grid=[0.0, 0.3, 0.5, 0.7, 1.0],\n",
        "    n_trials=10, seed=42,\n",
        ")\n",
        "\n",
        "# Generate initial graph and features\n",
        "A0, labels = generate_sbm_graph(\n",
        "    cfg['n'], cfg['pin'], cfg['pout'], cfg['n_classes'], seed=cfg['seed']\n",
        ")\n",
        "X0 = np.eye(cfg['d_feat'])[labels]\n",
        "\n",
        "recon_stats, acc_stats = [], []\n",
        "for gamma in cfg['gamma_grid']:\n",
        "    errs, accs = [], []\n",
        "    for trial in tqdm(range(cfg['n_trials']), desc=f\"γ={gamma:.2f}\"):\n",
        "        A_tilde, X_tilde = coupled_noise_forward(\n",
        "            A0, X0, cfg['beta'], gamma,\n",
        "            cfg['sigma_x'], cfg['sigma_a'], seed=cfg['seed'] + trial\n",
        "        )\n",
        "        A_hat, X_hat = simple_denoise(A_tilde, X_tilde, cfg['thresh'])\n",
        "        errs.append(reconstruction_error(A0, A_hat, X0, X_hat))\n",
        "        accs.append(\n",
        "            structure_based_classification_accuracy(\n",
        "                A_hat, labels, cfg['n_classes']\n",
        "            )\n",
        "        )\n",
        "    recon_stats.append(ci95(errs))\n",
        "    acc_stats.append(ci95(accs))\n",
        "\n",
        "# ---------- Plot results and download ----------\n",
        "fig, axes = plt.subplots(1, 2, figsize=(9, 3.8))\n",
        "letters = ['(a)', '(b)']\n",
        "\n",
        "# (a) Reconstruction error ±95% CI\n",
        "x = cfg['gamma_grid']\n",
        "mean_err = [m for m, _ in recon_stats]\n",
        "err_ci   = [h for _, h in recon_stats]\n",
        "axes[0].errorbar(x, mean_err, yerr=err_ci, marker='o',\n",
        "                 capsize=3, color='tab:blue')\n",
        "axes[0].set_xlabel(r'$\\gamma$')\n",
        "axes[0].set_ylabel('Reconstruction error')\n",
        "axes[0].set_title('Reconstruction error vs. γ')\n",
        "axes[0].grid(ls='--', alpha=0.4)\n",
        "\n",
        "# (b) Classification accuracy ±95% CI\n",
        "mean_acc = [m for m, _ in acc_stats]\n",
        "acc_ci   = [h for _, h in acc_stats]\n",
        "axes[1].errorbar(x, mean_acc, yerr=acc_ci, marker='o',\n",
        "                 capsize=3, color='tab:green')\n",
        "axes[1].set_xlabel(r'$\\gamma$')\n",
        "axes[1].set_ylabel('Classification accuracy')\n",
        "axes[1].set_title('Accuracy vs. γ')\n",
        "axes[1].grid(ls='--', alpha=0.4)\n",
        "\n",
        "# Annotate subplots\n",
        "for i, ax in enumerate(axes):\n",
        "    ax.text(-0.13, 1.05, letters[i], transform=ax.transAxes,\n",
        "            fontsize=11, fontweight='bold', va='top', ha='right')\n",
        "\n",
        "fig.tight_layout()\n",
        "pdf_name, png_name = 'gamma_coupled_noise_results.pdf', 'gamma_coupled_noise_results.png'\n",
        "fig.savefig(pdf_name)\n",
        "fig.savefig(png_name, dpi=300)\n",
        "plt.close(fig)\n",
        "\n",
        "# Automatically download the generated files\n",
        "files.download(pdf_name)\n",
        "files.download(png_name)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 106
        },
        "id": "2tN0DmWRS_gq",
        "outputId": "2ab0479f-cf31-4cdf-e718-abe09feb0518"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "γ=0.00: 100%|██████████| 10/10 [00:00<00:00, 44.14it/s]\n",
            "γ=0.30: 100%|██████████| 10/10 [00:00<00:00, 45.38it/s]\n",
            "γ=0.50: 100%|██████████| 10/10 [00:00<00:00, 44.69it/s]\n",
            "γ=0.70: 100%|██████████| 10/10 [00:00<00:00, 44.53it/s]\n",
            "γ=1.00: 100%|██████████| 10/10 [00:00<00:00, 44.50it/s]\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_69154d9b-c2bf-4e59-bab7-41fffac9b938\", \"gamma_coupled_noise_results.pdf\", 19370)"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ],
            "application/javascript": [
              "download(\"download_2d172f05-cd2a-4920-af31-b06f7191cd31\", \"gamma_coupled_noise_results.png\", 189002)"
            ]
          },
          "metadata": {}
        }
      ]
    }
  ]
}