{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Figure 1: Phase Transition Validation\n",
    "\n",
    "This notebook creates a 3-panel figure validating the phase transition theory in PLS-SVD with missing data.\n",
    "\n",
    "**Panels:**\n",
    "- (a) Phase transition curve showing R_x^2 and R_y^2 as functions of normalized signal strength\n",
    "- (b) 2D phase diagram heatmap with theoretical boundary overlay\n",
    "- (c) Finite-size sharpening demonstrating transition becomes sharper with increasing N"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "from multiprocessing import Pool\n",
    "from src import ModelParams\n",
    "from src import _run_experiment_worker, _run_grid_worker, _run_n_worker\n",
    "from tqdm.notebook import tqdm\n",
    "\n",
    "# ICML-compatible styling with increased font sizes\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",
   "metadata": {},
   "source": [
    "## Parameters\n",
    "\n",
    "The x-axis shows theta/theta_crit, the signal strength normalized by the critical threshold.\n",
    "- theta/theta_crit < 1: Subcritical regime (no recovery, R^2 = 0)\n",
    "- theta/theta_crit = 1: Phase transition point\n",
    "- theta/theta_crit > 1: Supercritical regime (successful recovery)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading results from file...\n",
      "  Loaded! θ_crit = 0.488\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# ============================================================================\n",
    "# EXPERIMENT 1A: θ sweep for panel (a)\n",
    "# ============================================================================\n",
    "import pickle\n",
    "import os\n",
    "\n",
    "# Parameters\n",
    "N = 1000\n",
    "Dx = 200\n",
    "Dy = 50\n",
    "mx = 0.3\n",
    "my = 0.4\n",
    "\n",
    "# Check if results exist\n",
    "results_dir = '../results'\n",
    "results_file = os.path.join(results_dir, 'fig1_results.pkl')\n",
    "\n",
    "if os.path.exists(results_file):\n",
    "    print(\"Loading results from file...\")\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    data = all_results['theta_sweep']\n",
    "    results_1a = data['results']\n",
    "    theta_crit_1a = data['theta_crit']\n",
    "    print(f\"  Loaded! θ_crit = {theta_crit_1a:.3f}\\n\")\n",
    "else:\n",
    "    print(\"Running Experiment 1A: θ sweep...\")\n",
    "    \n",
    "    # Get theta_crit\n",
    "    base_params = ModelParams(N=N, Dx=Dx, Dy=Dy, theta=1.0, mx=mx, my=my)\n",
    "    theta_crit_1a = base_params.theta_crit\n",
    "    \n",
    "    print(f\"  θ_crit = {theta_crit_1a:.3f}\")\n",
    "    \n",
    "    # Sweep theta\n",
    "    theta_values_1a = np.linspace(0.5 * theta_crit_1a, 2.5 * theta_crit_1a, 25)\n",
    "    n_trials = 100  # Increased from 60\n",
    "    \n",
    "    # Prepare arguments for parallel execution (convert to dicts for pickling)\n",
    "    args_list = []\n",
    "    for theta in theta_values_1a:\n",
    "        params_dict = {'N': N, 'Dx': Dx, 'Dy': Dy, 'theta': theta, 'mx': mx, 'my': my}\n",
    "        args_list.append((params_dict, n_trials))\n",
    "    \n",
    "    # Run in parallel with single progress bar\n",
    "    with Pool() as pool:\n",
    "        results_raw = list(tqdm(pool.imap(_run_experiment_worker, args_list),\n",
    "                                total=len(args_list), desc=\"  Exp 1A\"))\n",
    "    \n",
    "    # Add metadata\n",
    "    results_1a = []\n",
    "    for i, result in enumerate(results_raw):\n",
    "        result['theta'] = theta_values_1a[i]\n",
    "        result['theta_norm'] = theta_values_1a[i] / theta_crit_1a\n",
    "        results_1a.append(result)\n",
    "    \n",
    "    # Save results (will be combined with other experiments)\n",
    "    os.makedirs(results_dir, exist_ok=True)\n",
    "    all_results = {}\n",
    "    all_results['theta_sweep'] = {\n",
    "        'results': results_1a,\n",
    "        'theta_crit': theta_crit_1a,\n",
    "        'N': N,\n",
    "        'Dx': Dx,\n",
    "        'Dy': Dy,\n",
    "        'mx': mx,\n",
    "        'my': my\n",
    "    }\n",
    "    with open(results_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    \n",
    "    print(\"  Done! Results saved.\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading phase diagram results...\n",
      "  Loaded! Correlation (theory vs empirical): 0.9943\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# ============================================================================\n",
    "# EXPERIMENT 1B: Phase diagram for panel (b)\n",
    "# ============================================================================\n",
    "\n",
    "# Parameters\n",
    "N = 1000\n",
    "Dx = 150\n",
    "Dy = 120\n",
    "\n",
    "# Check if results exist\n",
    "results_file = os.path.join(results_dir, 'fig1_results.pkl')\n",
    "\n",
    "if os.path.exists(results_file):\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    if 'phase_diagram' in all_results:\n",
    "        print(\"Loading phase diagram results...\")\n",
    "        data = all_results['phase_diagram']\n",
    "        Rx2_empirical = data['Rx2_empirical']\n",
    "        Rx2_theoretical = data['Rx2_theoretical']\n",
    "        theta_grid = data['theta_grid']\n",
    "        rho_grid = data['rho_grid']\n",
    "        correlation = data['correlation']\n",
    "        print(f\"  Loaded! Correlation (theory vs empirical): {correlation:.4f}\\n\")\n",
    "        \n",
    "        # Reconstruct theoretical phase boundary function\n",
    "        alpha_x = N / Dx\n",
    "        alpha_y = N / Dy\n",
    "        theta_crit_func = lambda rho: 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))\n",
    "    else:\n",
    "        raise KeyError(\"phase_diagram not found in results file\")\n",
    "else:\n",
    "    print(\"Running Experiment 1C: Phase diagram...\")\n",
    "    \n",
    "    # Grid - Updated ranges\n",
    "    theta_grid = np.linspace(0.5, 2.0, 30)\n",
    "    rho_grid = np.linspace(0.1, 0.95, 30)\n",
    "    n_trials = 30\n",
    "    \n",
    "    # Theoretical phase boundary\n",
    "    alpha_x = N / Dx\n",
    "    alpha_y = N / Dy\n",
    "    theta_crit_func = lambda rho: 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))\n",
    "    \n",
    "    # Prepare arguments for parallel execution (flatten grid, convert to dicts)\n",
    "    args_list = []\n",
    "    for i, rho in enumerate(rho_grid):\n",
    "        m = 1 - np.sqrt(rho)\n",
    "        for j, theta in enumerate(theta_grid):\n",
    "            params_dict = {'N': N, 'Dx': Dx, 'Dy': Dy, 'theta': theta, 'mx': m, 'my': m}\n",
    "            args_list.append((params_dict, n_trials, i, j))\n",
    "    \n",
    "    # Run in parallel with single progress bar\n",
    "    with Pool() as pool:\n",
    "        results_raw = list(tqdm(pool.imap(_run_grid_worker, args_list),\n",
    "                                total=len(args_list), desc=\"  Exp 1C\"))\n",
    "    \n",
    "    # Fill matrices\n",
    "    Rx2_empirical = np.zeros((len(rho_grid), len(theta_grid)))\n",
    "    Rx2_theoretical = np.zeros((len(rho_grid), len(theta_grid)))\n",
    "    \n",
    "    for i, j, rx2_emp, rx2_theory in results_raw:\n",
    "        Rx2_empirical[i, j] = rx2_emp\n",
    "        Rx2_theoretical[i, j] = rx2_theory\n",
    "    \n",
    "    # Compute correlation\n",
    "    correlation = np.corrcoef(Rx2_empirical.flatten(), Rx2_theoretical.flatten())[0, 1]\n",
    "    \n",
    "    # Save results (add to existing file)\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    all_results['phase_diagram'] = {\n",
    "        'Rx2_empirical': Rx2_empirical,\n",
    "        'Rx2_theoretical': Rx2_theoretical,\n",
    "        'theta_grid': theta_grid,\n",
    "        'rho_grid': rho_grid,\n",
    "        'correlation': correlation,\n",
    "        'N': N,\n",
    "        'Dx': Dx,\n",
    "        'Dy': Dy\n",
    "    }\n",
    "    with open(results_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    \n",
    "    print(f\"  Correlation (theory vs empirical): {correlation:.4f}\")\n",
    "    print(\"  Done! Results saved.\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading finite size results...\n",
      "  Loaded! N_configs = [100, 250, 500, 1000, 2000, 5000]\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# ============================================================================\n",
    "# EXPERIMENT 1C: Finite-size sharpening for panel (c)\n",
    "# ============================================================================\n",
    "\n",
    "# Different N values\n",
    "N_configs = [100, 250, 500, 1000, 2000, 5000]\n",
    "alpha_x = 2.5\n",
    "alpha_y = 2.5\n",
    "mx = my = 0.2\n",
    "\n",
    "# Check if results exist\n",
    "results_file = os.path.join(results_dir, 'fig1_results.pkl')\n",
    "\n",
    "if os.path.exists(results_file):\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    if 'finite_size' in all_results:\n",
    "        print(\"Loading finite size results...\")\n",
    "        data = all_results['finite_size']\n",
    "        results_2c = data['results']\n",
    "        N_configs = data['N_configs']\n",
    "        alpha_x = data['alpha_x']\n",
    "        alpha_y = data['alpha_y']\n",
    "        mx = data['mx']\n",
    "        my = data['my']\n",
    "        print(f\"  Loaded! N_configs = {N_configs}\\n\")\n",
    "    else:\n",
    "        raise KeyError(\"finite_size not found in results file\")\n",
    "else:\n",
    "    print(\"Running Experiment 2C: Finite-size sharpening...\")\n",
    "    \n",
    "    # Prepare arguments for all N configurations (convert to dicts)\n",
    "    args_list = []\n",
    "    \n",
    "    for N in N_configs:\n",
    "        Dx = int(N / alpha_x)\n",
    "        Dy = int(N / alpha_y)\n",
    "        \n",
    "        # Get critical theta\n",
    "        params_temp = ModelParams(N=N, Dx=Dx, Dy=Dy, theta=1.0, mx=mx, my=my)\n",
    "        theta_crit = params_temp.theta_crit\n",
    "        \n",
    "        # Sweep theta in narrow window around theta_crit\n",
    "        theta_values = np.linspace(0.85 * theta_crit, 1.15 * theta_crit, 20)\n",
    "        n_trials = 30\n",
    "        \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, n_trials, N, theta, theta_crit))\n",
    "    \n",
    "    # Run in parallel with single progress bar\n",
    "    with Pool() as pool:\n",
    "        results_all = list(tqdm(pool.imap(_run_n_worker, args_list),\n",
    "                                total=len(args_list), desc=\"  Exp 2C\"))\n",
    "    \n",
    "    # Organize results by N\n",
    "    results_2c = {N: [] for N in N_configs}\n",
    "    for result in results_all:\n",
    "        results_2c[result['N']].append(result)\n",
    "    \n",
    "    # Sort by theta_norm for each N\n",
    "    for N in N_configs:\n",
    "        results_2c[N] = sorted(results_2c[N], key=lambda x: x['theta_norm'])\n",
    "    \n",
    "    # Save results (add to existing file)\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    all_results['finite_size'] = {\n",
    "        'results': results_2c,\n",
    "        'N_configs': N_configs,\n",
    "        'alpha_x': alpha_x,\n",
    "        'alpha_y': alpha_y,\n",
    "        'mx': mx,\n",
    "        'my': my\n",
    "    }\n",
    "    with open(results_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    \n",
    "    print(\"  Done! Results saved.\\n\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x200 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "======================================================================\n",
      "Figure saved: ../figures/fig1_phase_transition_validation.pdf\n",
      "======================================================================\n",
      "\n",
      "Dimensions: 7.0 × 2.4 inches (ICML two-column width)\n",
      "\n",
      "Panel (a): Phase transition with θ_crit = 0.488\n",
      "Panel (b): Phase diagram with correlation r = 0.9943\n",
      "Panel (c): Finite-size sharpening (N = 100 to 5000)\n"
     ]
    }
   ],
   "source": [
    "# Create figure with GridSpec\n",
    "fig = plt.figure(figsize=(7.0, 2.0))\n",
    "gs = gridspec.GridSpec(1, 3, width_ratios=[1, 1.4, 1],\n",
    "                       wspace=0.35, left=0.06, right=0.98,\n",
    "                       bottom=0.16, top=0.96)\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",
    "# ============================================================================\n",
    "# PANEL (a): Phase Transition (θ sweep) - Combined R_x² and R_y²\n",
    "# ============================================================================\n",
    "theta_norm_1a = [r['theta_norm'] for r in results_1a]\n",
    "\n",
    "# R_x² - mean line with circles\n",
    "ax_a.plot(theta_norm_1a,\n",
    "          [r['Rx2_pls_mean'] for r in results_1a],\n",
    "          'o-', markersize=3, linewidth=0.8,\n",
    "          color='C0', label=r'$R_x^2$ (emp.)')\n",
    "\n",
    "# R_x² - uncertainty band\n",
    "ax_a.fill_between(theta_norm_1a,\n",
    "                  [r['Rx2_pls_mean'] - r['Rx2_pls_std'] for r in results_1a],\n",
    "                  [r['Rx2_pls_mean'] + r['Rx2_pls_std'] for r in results_1a],\n",
    "                  color='C0', alpha=0.25, linewidth=0)\n",
    "\n",
    "# R_y² - mean line with squares\n",
    "ax_a.plot(theta_norm_1a,\n",
    "          [r['Ry2_pls_mean'] for r in results_1a],\n",
    "          's-', markersize=3, linewidth=0.8,\n",
    "          color='C1', label=r'$R_y^2$ (emp.)')\n",
    "\n",
    "# R_y² - uncertainty band\n",
    "ax_a.fill_between(theta_norm_1a,\n",
    "                  [r['Ry2_pls_mean'] - r['Ry2_pls_std'] for r in results_1a],\n",
    "                  [r['Ry2_pls_mean'] + r['Ry2_pls_std'] for r in results_1a],\n",
    "                  color='C1', alpha=0.25, linewidth=0)\n",
    "\n",
    "# Theory curves\n",
    "ax_a.plot(theta_norm_1a, [r['Rx2_theory'] for r in results_1a],\n",
    "          'k--', linewidth=1.2, label='Theory')\n",
    "ax_a.plot(theta_norm_1a, [r['Ry2_theory'] for r in results_1a],\n",
    "          'k--', linewidth=1.2)\n",
    "\n",
    "# Critical threshold marker\n",
    "ax_a.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7,\n",
    "             label=r'$\\theta_{\\mathrm{crit}}$')\n",
    "\n",
    "ax_a.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
    "ax_a.set_ylabel(r'$R^2$')\n",
    "ax_a.set_ylim([-0.05, 1.05])\n",
    "ax_a.legend(loc='lower left', bbox_to_anchor=(0.4, 0.0), frameon=False, labelspacing=0.15)\n",
    "ax_a.text(-0.20, 1.08, '(a)', transform=ax_a.transAxes,\n",
    "          fontsize=10, fontweight='bold', va='top')\n",
    "\n",
    "# ============================================================================\n",
    "# PANEL (b): Phase Diagram - Centerpiece\n",
    "# ============================================================================\n",
    "# Show empirical heatmap only (theory correlation > 0.998)\n",
    "im = ax_b.imshow(Rx2_empirical, \n",
    "                 extent=[theta_grid[0], theta_grid[-1], rho_grid[0], rho_grid[-1]],\n",
    "                 origin='lower', aspect='auto', cmap='viridis', vmin=0, vmax=1)\n",
    "\n",
    "# Crop to desired ranges\n",
    "ax_b.set_xlim([0.5, 2.0])\n",
    "ax_b.set_ylim([0.1, 0.95])\n",
    "\n",
    "# Phase boundary overlay\n",
    "rho_fine = np.linspace(0.1, 0.95, 100)\n",
    "theta_boundary = [theta_crit_func(r) for r in rho_fine]\n",
    "ax_b.plot(theta_boundary, rho_fine, 'r--', linewidth=1.5, \n",
    "          label='Phase boundary')\n",
    "\n",
    "# Add correlation annotation\n",
    "ax_b.text(0.98, 0.05, f'$r = {correlation:.3f}$', \n",
    "          transform=ax_b.transAxes, fontsize=7, \n",
    "          ha='right', va='bottom', color='white',\n",
    "          bbox=dict(boxstyle='round,pad=0.3', facecolor='black', alpha=0.5))\n",
    "\n",
    "ax_b.set_xlabel(r'$\\theta$')\n",
    "ax_b.set_ylabel(r'$\\rho$')\n",
    "ax_b.legend(loc='upper right', frameon=False)\n",
    "ax_b.text(-0.20, 1.08, '(b)', transform=ax_b.transAxes,\n",
    "          fontsize=10, fontweight='bold', va='top')\n",
    "\n",
    "# Colorbar with better sizing and positioning to avoid overlap\n",
    "cbar = plt.colorbar(im, ax=ax_b, fraction=0.046, pad=0.02, aspect=25)\n",
    "cbar.set_label(r'$R_x^2$', fontsize=8, labelpad=8)\n",
    "cbar.ax.tick_params(labelsize=7)\n",
    "\n",
    "# ============================================================================\n",
    "# PANEL (c): Finite-Size Sharpening\n",
    "# ============================================================================\n",
    "# Sequential colors for different N values\n",
    "colors_n = plt.cm.viridis(np.linspace(0.15, 0.85, len(N_configs)))\n",
    "\n",
    "for i, N in enumerate(N_configs):\n",
    "    results = results_2c[N]\n",
    "    theta_norm = [r['theta_norm'] for r in results]\n",
    "    Rx2_mean = [r['Rx2_pls_mean'] for r in results]\n",
    "    \n",
    "    # No error bars (reduce clutter)\n",
    "    ax_c.plot(theta_norm, Rx2_mean, 'o-',\n",
    "              markersize=2.5, linewidth=0.8,\n",
    "              color=colors_n[i], label=f'$N = {N}$')\n",
    "\n",
    "# Theoretical curve (N → ∞)\n",
    "theta_norm_theory = [r['theta_norm'] for r in results_2c[N_configs[-1]]]\n",
    "Rx2_theory = [r['Rx2_theory'] for r in results_2c[N_configs[-1]]]\n",
    "ax_c.plot(theta_norm_theory, Rx2_theory, 'k--', linewidth=1.2,\n",
    "          label=r'Theory ($N\\to\\infty$)', zorder=10)\n",
    "\n",
    "# Critical threshold marker\n",
    "ax_c.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7, ymax=0.4)\n",
    "\n",
    "# Arrow annotation for N increase\n",
    "# ax_c.annotate('', xy=(0.98, 0.75), xytext=(0.98, 0.25),\n",
    "#               xycoords='axes fraction',\n",
    "#               arrowprops=dict(arrowstyle='->', lw=1.2, color='gray'))\n",
    "# ax_c.text(1.02, 0.5, r'$N \\uparrow$', transform=ax_c.transAxes,\n",
    "#           fontsize=7, color='gray', rotation=90, va='center')\n",
    "\n",
    "ax_c.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
    "ax_c.set_ylabel(r'$R_x^2$')\n",
    "ax_c.set_ylim([-0.05, 1.05])\n",
    "ax_c.legend(loc='upper left', frameon=False, ncol=1, labelspacing=0.1)\n",
    "ax_c.text(-0.20, 1.08, '(c)', transform=ax_c.transAxes,\n",
    "          fontsize=10, fontweight='bold', va='top')\n",
    "\n",
    "# ============================================================================\n",
    "# Save figure\n",
    "# ============================================================================\n",
    "plt.savefig('../figures/fig1_phase_transition_validation.pdf',\n",
    "            dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "print(\"\\n\" + \"=\"*70)\n",
    "print(\"Figure saved: ../figures/fig1_phase_transition_validation.pdf\")\n",
    "print(\"=\"*70)\n",
    "print(f\"\\nDimensions: 7.0 × 2.4 inches (ICML two-column width)\")\n",
    "print(f\"\\nPanel (a): Phase transition with θ_crit = {theta_crit_1a:.3f}\")\n",
    "print(f\"Panel (b): Phase diagram with correlation r = {correlation:.4f}\")\n",
    "print(f\"Panel (c): Finite-size sharpening (N = 100 to 5000)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": 4
}
