{
  "cells": [
    {
      "cell_type": "markdown",
      "id": "cell-0",
      "metadata": {},
      "source": [
        "# Figure A1: Robustness to Non-Gaussian Noise (Supplementary)\n",
        "\n",
        "This notebook tests the robustness of the phase transition theory to violations of the Gaussian noise assumption by comparing multiple heavy-tailed and heteroskedastic distributions.\n",
        "\n",
        "**Figure layout (3 panels):**\n",
        "- (a) Phase transition curves R_x^2 for each noise type\n",
        "- (b) Phase transition curves R_y^2 for each noise type\n",
        "- (c) Theory deviation (MAE) vs excess kurtosis"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "id": "cell-1",
      "metadata": {},
      "outputs": [],
      "source": [
        "import os\n",
        "import pickle\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import matplotlib.gridspec as gridspec\n",
        "from multiprocessing import Pool\n",
        "from tqdm.notebook import tqdm\n",
        "\n",
        "from src import (\n",
        "    ModelParams, generate_data_non_gaussian, pls_svd, compute_overlaps,\n",
        "    theoretical_overlaps, run_multiple_trials_non_gaussian, _run_non_gaussian_worker\n",
        ")\n",
        "\n",
        "# ICML-compatible styling\n",
        "plt.rcParams.update({\n",
        "    'font.size': 9,\n",
        "    'axes.labelsize': 9,\n",
        "    'xtick.labelsize': 8,\n",
        "    'ytick.labelsize': 8,\n",
        "    'legend.fontsize': 7,\n",
        "    'font.family': 'serif',\n",
        "    'mathtext.fontset': 'cm',\n",
        "    'axes.spines.top': False,\n",
        "    'axes.spines.right': False,\n",
        "})\n",
        "\n",
        "np.random.seed(42)"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "cell-2",
      "metadata": {},
      "source": [
        "## 1. Define Noise Distributions\n",
        "| Distribution | Variance | Excess Kurtosis | Notes |\n",
        "|-------------|----------|-----------------|-------|\n",
        "| Gaussian N(0,1) | 1 | 0 | Theory baseline |\n",
        "| Student-t(5) | 1 (scaled) | 6 | Moderate heavy tails |\n",
        "| Student-t(4.5) | 1 (scaled) | 12 | Heavy tails |\n",
        "| Student-t(3) | 1 (scaled) | ∞ | Infinite kurtosis |\n",
        "| Laplace(0, 1/√2) | 1 | 3 | Different tail decay |\n",
        "| Heteroskedastic | ~1 (avg) | varies | Non-i.i.d. variance |\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "id": "cell-3",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Noise distributions to test:\n",
            "  Gaussian                  - Excess kurtosis: 0.0\n",
            "  Student-t (df=5)          - Excess kurtosis: 6.0\n",
            "  Student-t (df=4.5)        - Excess kurtosis: 12.0\n",
            "  Student-t (df=3)          - Excess kurtosis: ∞\n",
            "  Laplace                   - Excess kurtosis: 3.0\n",
            "  Heteroskedastic           - Excess kurtosis: 0.6\n"
          ]
        }
      ],
      "source": [
        "# Noise distribution metadata\n",
        "# For Student-t: excess kurtosis = 6/(df-4) for df > 4\n",
        "NOISE_TYPES = {\n",
        "    'gaussian': {\n",
        "        'label': 'Gaussian',\n",
        "        'excess_kurtosis': 0,\n",
        "        'color': 'C0',\n",
        "        'marker': 'o',\n",
        "    },\n",
        "    't5': {\n",
        "        'label': 'Student-t (df=5)',\n",
        "        'excess_kurtosis': 6,  # 6/(5-4) = 6\n",
        "        'color': 'C1',\n",
        "        'marker': 's',\n",
        "    },\n",
        "    't4.5': {\n",
        "        'label': 'Student-t (df=4.5)',\n",
        "        'excess_kurtosis': 12,  # 6/(4.5-4) = 12\n",
        "        'color': 'C2',\n",
        "        'marker': '^',\n",
        "    },\n",
        "    't3': {\n",
        "        'label': 'Student-t (df=3)',\n",
        "        'excess_kurtosis': np.inf,  # undefined for df <= 4\n",
        "        'color': 'C5',\n",
        "        'marker': 'D',\n",
        "    },\n",
        "    'laplace': {\n",
        "        'label': 'Laplace',\n",
        "        'excess_kurtosis': 3,\n",
        "        'color': 'C3',\n",
        "        'marker': 'v',\n",
        "    },\n",
        "    'heteroskedastic': {\n",
        "        'label': 'Heteroskedastic',\n",
        "        'excess_kurtosis': 0.6,  # Approximate for uniform-scaled Gaussian\n",
        "        'color': 'C4',\n",
        "        'marker': 'd',\n",
        "    },\n",
        "}\n",
        "\n",
        "print(\"Noise distributions to test:\")\n",
        "for name, info in NOISE_TYPES.items():\n",
        "    kurt = info['excess_kurtosis']\n",
        "    kurt_str = f\"{kurt:.1f}\" if np.isfinite(kurt) else \"∞\"\n",
        "    print(f\"  {info['label']:25s} - Excess kurtosis: {kurt_str}\")"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "cell-4",
      "metadata": {},
      "source": [
        "## 2. Experiment Setup"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "id": "cell-5",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Parameters:\n",
            "  N=1000, Dx=200, Dy=150\n",
            "  mx=0.3, my=0.3, ρ=0.49\n",
            "  θ_crit = 0.5945\n",
            "  θ range: [0.357, 1.189]\n",
            "  n_trials = 100\n"
          ]
        }
      ],
      "source": [
        "# Fixed parameters\n",
        "N = 1000\n",
        "Dx = 200\n",
        "Dy = 150\n",
        "mx = my = 0.3\n",
        "n_trials = 100\n",
        "\n",
        "# Compute theta_crit\n",
        "alpha_x = N / Dx\n",
        "alpha_y = N / Dy\n",
        "rho = (1 - mx) * (1 - my)\n",
        "theta_crit = 1 / ((alpha_x * alpha_y) ** 0.25 * np.sqrt(rho))\n",
        "\n",
        "# Theta sweep\n",
        "theta_values = np.linspace(0.6 * theta_crit, 2.0 * theta_crit, 25)\n",
        "\n",
        "print(f\"Parameters:\")\n",
        "print(f\"  N={N}, Dx={Dx}, Dy={Dy}\")\n",
        "print(f\"  mx={mx}, my={my}, ρ={(1-mx)*(1-my):.2f}\")\n",
        "print(f\"  θ_crit = {theta_crit:.4f}\")\n",
        "print(f\"  θ range: [{theta_values[0]:.3f}, {theta_values[-1]:.3f}]\")\n",
        "print(f\"  n_trials = {n_trials}\")"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "cell-6",
      "metadata": {},
      "source": [
        "## 3. Run Experiments"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "id": "cell-7",
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Running experiments...\n",
            "\n",
            "  Processing Gaussian...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "9a6e74b1585d4c698af62a0b74096d37",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "  Processing Student-t (df=5)...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "96a02133a0944cd48fd295af9c98cdbc",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "  Processing Student-t (df=4.5)...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "a46c640e098c401796a405bd71a732d7",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "  Processing Student-t (df=3)...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "6ed10718bc7242749585396d20f2afdb",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "  Processing Laplace...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "e1e9d8efde39481f83fd0e0f6d81f8dd",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "  Processing Heteroskedastic...\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "1fed24e52acc4e7385903d41f14ec6f0",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "    θ sweep:   0%|          | 0/25 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "Results cached!\n"
          ]
        }
      ],
      "source": [
        "# Check for cached results\n",
        "results_dir = '../results'\n",
        "os.makedirs(results_dir, exist_ok=True)\n",
        "cache_file = os.path.join(results_dir, 'figA1_results.pkl')\n",
        "\n",
        "if os.path.exists(cache_file):\n",
        "    print(\"Loading cached results...\")\n",
        "    with open(cache_file, 'rb') as f:\n",
        "        all_results = pickle.load(f)\n",
        "    print(\"Done!\")\n",
        "else:\n",
        "    print(\"Running experiments...\")\n",
        "    all_results = {}\n",
        "    \n",
        "    for noise_type in NOISE_TYPES.keys():\n",
        "        print(f\"\\n  Processing {NOISE_TYPES[noise_type]['label']}...\")\n",
        "        results = []\n",
        "        \n",
        "        # Prepare arguments for parallel execution\n",
        "        args_list = []\n",
        "        for theta in theta_values:\n",
        "            params_dict = {'N': N, 'Dx': Dx, 'Dy': Dy, 'theta': theta, 'mx': mx, 'my': my}\n",
        "            args_list.append((params_dict, noise_type, n_trials, theta, theta_crit))\n",
        "        \n",
        "        # Run in parallel\n",
        "        with Pool() as pool:\n",
        "            results = list(tqdm(pool.imap(_run_non_gaussian_worker, args_list),\n",
        "                               total=len(args_list), desc=f\"    θ sweep\"))\n",
        "        \n",
        "        all_results[noise_type] = results\n",
        "    \n",
        "    # Cache results\n",
        "    with open(cache_file, 'wb') as f:\n",
        "        pickle.dump(all_results, f)\n",
        "    print(\"\\nResults cached!\")"
      ]
    },
    {
      "cell_type": "markdown",
      "id": "cell-8",
      "metadata": {},
      "source": [
        "## 4. Create Publication Figure"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 11,
      "id": "cell-9",
      "metadata": {},
      "outputs": [
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 700x250 with 3 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "\n",
            "Figure saved: ../figures/figA1_robustness_analysis.pdf\n"
          ]
        }
      ],
      "source": [
        "fig = plt.figure(figsize=(7.0, 2.5))\n",
        "gs = gridspec.GridSpec(1, 3, wspace=0.35,\n",
        "                       left=0.07, right=0.98, bottom=0.16, top=0.92)\n",
        "\n",
        "ax_a = fig.add_subplot(gs[0])\n",
        "ax_b = fig.add_subplot(gs[1])\n",
        "ax_c = fig.add_subplot(gs[2])\n",
        "\n",
        "# --- Panel (a): R_x² phase transition curves ---\n",
        "for noise_type, info in NOISE_TYPES.items():\n",
        "    results = all_results[noise_type]\n",
        "    theta_norm = [r['theta_norm'] for r in results]\n",
        "    rx2_mean = [r['Rx2_pls_mean'] for r in results]\n",
        "    rx2_std = [r['Rx2_pls_std'] for r in results]\n",
        "    \n",
        "    ax_a.plot(theta_norm, rx2_mean,\n",
        "              marker=info['marker'], markersize=3, linewidth=0.8,\n",
        "              color=info['color'], label=info['label'])\n",
        "    ax_a.fill_between(theta_norm,\n",
        "                      np.array(rx2_mean) - np.array(rx2_std),\n",
        "                      np.array(rx2_mean) + np.array(rx2_std),\n",
        "                      color=info['color'], alpha=0.15, linewidth=0)\n",
        "\n",
        "# Theory (Gaussian)\n",
        "results_gauss = all_results['gaussian']\n",
        "ax_a.plot([r['theta_norm'] for r in results_gauss],\n",
        "          [r['Rx2_theory'] for r in results_gauss],\n",
        "          'k--', linewidth=1.5, label='Theory', zorder=10)\n",
        "\n",
        "ax_a.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7)\n",
        "ax_a.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
        "ax_a.set_ylabel(r'$R_x^2$')\n",
        "ax_a.set_ylim([-0.05, 1.05])\n",
        "ax_a.legend(loc='upper left', frameon=False, fontsize=4.5, ncol=1)\n",
        "ax_a.text(-0.18, 1.08, '(a)', transform=ax_a.transAxes,\n",
        "          fontsize=10, fontweight='bold', va='top')\n",
        "\n",
        "# --- Panel (b): R_y² phase transition curves ---\n",
        "for noise_type, info in NOISE_TYPES.items():\n",
        "    results = all_results[noise_type]\n",
        "    theta_norm = [r['theta_norm'] for r in results]\n",
        "    ry2_mean = [r['Ry2_pls_mean'] for r in results]\n",
        "    ry2_std = [r['Ry2_pls_std'] for r in results]\n",
        "    \n",
        "    ax_b.plot(theta_norm, ry2_mean,\n",
        "              marker=info['marker'], markersize=3, linewidth=0.8,\n",
        "              color=info['color'], label=info['label'])\n",
        "    ax_b.fill_between(theta_norm,\n",
        "                      np.array(ry2_mean) - np.array(ry2_std),\n",
        "                      np.array(ry2_mean) + np.array(ry2_std),\n",
        "                      color=info['color'], alpha=0.15, linewidth=0)\n",
        "\n",
        "# Theory (Gaussian)\n",
        "ax_b.plot([r['theta_norm'] for r in results_gauss],\n",
        "          [r['Ry2_theory'] for r in results_gauss],\n",
        "          'k--', linewidth=1.5, label='Theory', zorder=10)\n",
        "\n",
        "ax_b.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7)\n",
        "ax_b.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
        "ax_b.set_ylabel(r'$R_y^2$')\n",
        "ax_b.set_ylim([-0.05, 1.05])\n",
        "ax_b.text(-0.18, 1.08, '(b)', transform=ax_b.transAxes,\n",
        "          fontsize=10, fontweight='bold', va='top')\n",
        "\n",
        "# --- Panel (c): MAE vs Excess Kurtosis ---\n",
        "mae_values = []\n",
        "kurtosis_values = []\n",
        "kurtosis_plot_values = []\n",
        "labels = []\n",
        "\n",
        "for noise_type, info in NOISE_TYPES.items():\n",
        "    results = all_results[noise_type]\n",
        "    \n",
        "    # Compute MAE (only for supercritical regime to avoid trivial zeros)\n",
        "    rx2_emp = np.array([r['Rx2_pls_mean'] for r in results])\n",
        "    rx2_theory = np.array([r['Rx2_theory'] for r in results])\n",
        "    theta_norm = np.array([r['theta_norm'] for r in results])\n",
        "    \n",
        "    # Focus on supercritical regime (θ/θ_crit > 1.1)\n",
        "    mask = theta_norm > 1.1\n",
        "    if mask.sum() > 0:\n",
        "        mae = np.mean(np.abs(rx2_emp[mask] - rx2_theory[mask]))\n",
        "    else:\n",
        "        mae = np.nan\n",
        "    \n",
        "    kurt = info['excess_kurtosis']\n",
        "    if np.isfinite(kurt):\n",
        "        # For log scale, use small offset for kurtosis = 0 (Gaussian)\n",
        "        kurt_plot = max(kurt, 0.1) if kurt == 0 else kurt\n",
        "        kurtosis_values.append(kurt)\n",
        "        kurtosis_plot_values.append(kurt_plot)\n",
        "        mae_values.append(mae)\n",
        "        labels.append(info['label'])\n",
        "        ax_c.scatter(kurt_plot, mae, s=50, c=info['color'], marker=info['marker'],\n",
        "                    edgecolors='black', linewidths=0.5, zorder=5)\n",
        "    else:\n",
        "        # t3 has infinite kurtosis, plot at right edge with arrow\n",
        "        # Use log scale, so plot at a high value (e.g., 1000)\n",
        "        ax_c.scatter(1000, mae, s=50, c=info['color'], marker=info['marker'],\n",
        "                    edgecolors='black', linewidths=0.5, zorder=5)\n",
        "        ax_c.annotate('', xy=(1200, mae), xytext=(1000, mae),\n",
        "                     arrowprops=dict(arrowstyle='->', color=info['color'], lw=1.5))\n",
        "\n",
        "# Add labels next to points (only for a few key distributions to avoid clutter)\n",
        "for kurt_plot, mae, label in zip(kurtosis_plot_values, mae_values, labels):\n",
        "    if label == 'Gaussian':\n",
        "        ax_c.annotate(label, (kurt_plot, mae), xytext=(5, 5),\n",
        "                     textcoords='offset points', fontsize=6)\n",
        "    elif label == 'Laplace':\n",
        "        ax_c.annotate(label, (kurt_plot, mae), xytext=(5, -8),\n",
        "                     textcoords='offset points', fontsize=6)\n",
        "\n",
        "ax_c.set_xlabel('Excess Kurtosis')\n",
        "ax_c.set_ylabel(r'MAE$(R_x^2)$ from Theory')\n",
        "ax_c.set_xscale('log')\n",
        "ax_c.set_xlim([0.1, 2000])\n",
        "ax_c.set_ylim([0, None])\n",
        "ax_c.text(-0.18, 1.08, '(c)', transform=ax_c.transAxes,\n",
        "          fontsize=10, fontweight='bold', va='top')\n",
        "\n",
        "# Add annotation for t3 at infinity\n",
        "if len(mae_values) > 0:\n",
        "    # Find t3 result\n",
        "    t3_mae = None\n",
        "    for noise_type, info in NOISE_TYPES.items():\n",
        "        if info['label'] == 'Student-t (df=3)':\n",
        "            results = all_results[noise_type]\n",
        "            rx2_emp = np.array([r['Rx2_pls_mean'] for r in results])\n",
        "            rx2_theory = np.array([r['Rx2_theory'] for r in results])\n",
        "            theta_norm = np.array([r['theta_norm'] for r in results])\n",
        "            mask = theta_norm > 1.1\n",
        "            if mask.sum() > 0:\n",
        "                t3_mae = np.mean(np.abs(rx2_emp[mask] - rx2_theory[mask]))\n",
        "            break\n",
        "    if t3_mae is not None:\n",
        "        ax_c.text(1000, t3_mae, r't(3): $\\kappa\\to\\infty$',\n",
        "                  fontsize=6, ha='left', va='center')\n",
        "\n",
        "plt.savefig('../figures/figA1_robustness_analysis.pdf', dpi=300, bbox_inches='tight')\n",
        "plt.show()\n",
        "\n",
        "print(\"\\nFigure saved: ../figures/figA1_robustness_analysis.pdf\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "id": "432ac994",
      "metadata": {},
      "outputs": [],
      "source": []
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": ".venv",
      "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.14.2"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 5
}
