{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cell-0",
   "metadata": {},
   "source": [
    "# Figure 2: Missingness Effects Comparison\n",
    "\n",
    "This notebook creates a 2-panel figure comparing phase diagrams for single-view vs joint missingness patterns in PLS-SVD.\n",
    "\n",
    "**Panels:**\n",
    "- (a) Phase diagram for X-only missingness (m_Y = 0): rho = 1-m (linear degradation)\n",
    "- (b) Phase diagram for joint missingness (m_X = m_Y = m): rho = (1-m)^2 (quadratic degradation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cell-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 _run_grid_worker\n",
    "from tqdm.notebook import tqdm\n",
    "import pickle\n",
    "import os\n",
    "\n",
    "# ICML single-column 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)\n",
    "\n",
    "# Create directories\n",
    "os.makedirs('../results', exist_ok=True)\n",
    "os.makedirs('../figures', exist_ok=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-2",
   "metadata": {},
   "source": [
    "## Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "cell-3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Parameters: N=800, Dx=200, Dy=200\n",
      "Aspect ratios: alpha_x=4.0, alpha_y=4.0\n",
      "Grid: 50 x 50 = 2500 points\n"
     ]
    }
   ],
   "source": [
    "# Grid parameters for phase diagrams\n",
    "N_pd = 800\n",
    "Dx_pd = 200\n",
    "Dy_pd = 200\n",
    "theta_grid = np.linspace(0.3, 2.0, 50)\n",
    "m_grid = np.linspace(0.0, 0.9, 50)\n",
    "n_trials_pd = 30\n",
    "\n",
    "# Compute aspect ratios\n",
    "alpha_x = N_pd / Dx_pd\n",
    "alpha_y = N_pd / Dy_pd\n",
    "\n",
    "print(f\"Parameters: N={N_pd}, Dx={Dx_pd}, Dy={Dy_pd}\")\n",
    "print(f\"Aspect ratios: alpha_x={alpha_x:.1f}, alpha_y={alpha_y:.1f}\")\n",
    "print(f\"Grid: {len(theta_grid)} x {len(m_grid)} = {len(theta_grid)*len(m_grid)} points\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-4",
   "metadata": {},
   "source": [
    "## Phase Diagram 1: X-only Missingness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cell-5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading results...\n",
      "  Loaded X-only (50, 50) grid.\n"
     ]
    }
   ],
   "source": [
    "results_file = '../results/fig2_results.pkl'\n",
    "\n",
    "if os.path.exists(results_file):\n",
    "    print(\"Loading results...\")\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    data_d = all_results['x_only']\n",
    "    Rx2_empirical_d = data_d['Rx2_empirical']\n",
    "    Rx2_theoretical_d = data_d['Rx2_theoretical']\n",
    "    print(f\"  Loaded X-only {Rx2_empirical_d.shape} grid.\")\n",
    "else:\n",
    "    print(\"Running Phase diagram (X-only) experiment...\")\n",
    "    \n",
    "    args_list = []\n",
    "    for i, m in enumerate(m_grid):\n",
    "        for j, th in enumerate(theta_grid):\n",
    "            params_dict = {'N': N_pd, 'Dx': Dx_pd, 'Dy': Dy_pd, 'theta': th, 'mx': m, 'my': 0.0}\n",
    "            args_list.append((params_dict, n_trials_pd, i, j))\n",
    "    \n",
    "    with Pool() as pool:\n",
    "        results_raw = list(tqdm(pool.imap(_run_grid_worker, args_list),\n",
    "                                total=len(args_list), desc=\"  Phase (X-only)\"))\n",
    "    \n",
    "    Rx2_empirical_d = np.zeros((len(m_grid), len(theta_grid)))\n",
    "    Rx2_theoretical_d = np.zeros((len(m_grid), len(theta_grid)))\n",
    "    \n",
    "    for i, j, rx2_emp, rx2_theory in results_raw:\n",
    "        Rx2_empirical_d[i, j] = rx2_emp\n",
    "        Rx2_theoretical_d[i, j] = rx2_theory\n",
    "    \n",
    "    all_results = {}\n",
    "    all_results['x_only'] = {\n",
    "        'Rx2_empirical': Rx2_empirical_d,\n",
    "        'Rx2_theoretical': Rx2_theoretical_d,\n",
    "        'theta_grid': theta_grid,\n",
    "        'm_grid': m_grid,\n",
    "    }\n",
    "    with open(results_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    print(\"  Done! Results saved.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-6",
   "metadata": {},
   "source": [
    "## Phase Diagram 2: Joint Missingness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cell-7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  Loaded Joint (50, 50) grid.\n"
     ]
    }
   ],
   "source": [
    "if os.path.exists(results_file):\n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    if 'joint' in all_results:\n",
    "        data_e = all_results['joint']\n",
    "        Rx2_empirical_e = data_e['Rx2_empirical']\n",
    "        Rx2_theoretical_e = data_e['Rx2_theoretical']\n",
    "        print(f\"  Loaded Joint {Rx2_empirical_e.shape} grid.\")\n",
    "    else:\n",
    "        raise KeyError(\"joint not found in results file\")\n",
    "else:\n",
    "    print(\"Running Phase diagram (Joint) experiment...\")\n",
    "    \n",
    "    args_list = []\n",
    "    for i, m in enumerate(m_grid):\n",
    "        for j, th in enumerate(theta_grid):\n",
    "            params_dict = {'N': N_pd, 'Dx': Dx_pd, 'Dy': Dy_pd, 'theta': th, 'mx': m, 'my': m}\n",
    "            args_list.append((params_dict, n_trials_pd, i, j))\n",
    "    \n",
    "    with Pool() as pool:\n",
    "        results_raw = list(tqdm(pool.imap(_run_grid_worker, args_list),\n",
    "                                total=len(args_list), desc=\"  Phase (Joint)\"))\n",
    "    \n",
    "    Rx2_empirical_e = np.zeros((len(m_grid), len(theta_grid)))\n",
    "    Rx2_theoretical_e = np.zeros((len(m_grid), len(theta_grid)))\n",
    "    \n",
    "    for i, j, rx2_emp, rx2_theory in results_raw:\n",
    "        Rx2_empirical_e[i, j] = rx2_emp\n",
    "        Rx2_theoretical_e[i, j] = rx2_theory\n",
    "    \n",
    "    with open(results_file, 'rb') as f:\n",
    "        all_results = pickle.load(f)\n",
    "    all_results['joint'] = {\n",
    "        'Rx2_empirical': Rx2_empirical_e,\n",
    "        'Rx2_theoretical': Rx2_theoretical_e,\n",
    "        'theta_grid': theta_grid,\n",
    "        'm_grid': m_grid,\n",
    "    }\n",
    "    with open(results_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    print(\"  Done! Results saved.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-8",
   "metadata": {},
   "source": [
    "## Critical Threshold Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cell-9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def theta_crit_single(m, alpha_x, alpha_y):\n",
    "    \"\"\"Critical theta for single-view missingness.\n",
    "    \n",
    "    For X-only (my=0): rho = 1-m\n",
    "    theta_crit = 1 / [(alpha_x * alpha_y)^0.25 * sqrt(1-m)]\n",
    "    \"\"\"\n",
    "    rho = 1 - m\n",
    "    return 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))\n",
    "\n",
    "def theta_crit_joint(m, alpha_x, alpha_y):\n",
    "    \"\"\"Critical theta for joint missingness.\n",
    "    \n",
    "    For joint (mx=my=m): rho = (1-m)^2\n",
    "    theta_crit = 1 / [(alpha_x * alpha_y)^0.25 * (1-m)]\n",
    "    \"\"\"\n",
    "    rho = (1 - m)**2\n",
    "    return 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-10",
   "metadata": {},
   "source": [
    "## Create Phase Diagram Figure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cell-11",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/1h/rpjt93m90nxf1xwtn92lvfkw0000gn/T/ipykernel_69885/1218753458.py:8: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  return 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))\n",
      "/var/folders/1h/rpjt93m90nxf1xwtn92lvfkw0000gn/T/ipykernel_69885/1218753458.py:17: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  return 1 / ((alpha_x * alpha_y)**0.25 * np.sqrt(rho))\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 325x210 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "======================================================================\n",
      "Figure saved: ../figures/fig2_missingness_effects.pdf\n",
      "Dimensions: 3.25 x 2.1 inches (ICML single-column)\n",
      "======================================================================\n"
     ]
    }
   ],
   "source": [
    "# Create single-column figure (3.25\" wide for ICML)\n",
    "# Layout: 2 rows, 1 column (2 phase diagrams stacked, shared x-axis)\n",
    "\n",
    "fig = plt.figure(figsize=(3.25, 2.1))\n",
    "gs = gridspec.GridSpec(2, 1,\n",
    "                       left=0.08, right=0.73, bottom=0.18, top=0.93,\n",
    "                       hspace=0.08)\n",
    "\n",
    "# Two phase diagrams stacked vertically\n",
    "ax_d = fig.add_subplot(gs[0, 0])\n",
    "ax_e = fig.add_subplot(gs[1, 0], sharex=ax_d)\n",
    "\n",
    "# ============================================================================\n",
    "# TOP PANEL: X-only missingness phase diagram\n",
    "# ============================================================================\n",
    "im_d = ax_d.imshow(Rx2_empirical_d,\n",
    "                   extent=[theta_grid[0], theta_grid[-1], m_grid[0], m_grid[-1]],\n",
    "                   origin='lower', aspect='auto', cmap='viridis', vmin=0, vmax=1)\n",
    "\n",
    "# Phase boundary for X-only\n",
    "m_fine = np.linspace(0.01, 1.0, 100)\n",
    "theta_boundary_single = [theta_crit_single(m, alpha_x, alpha_y) for m in m_fine]\n",
    "ax_d.plot(theta_boundary_single, m_fine, 'r--', linewidth=1.0)\n",
    "\n",
    "ax_d.set_xlim([theta_grid[0], theta_grid[-1]])\n",
    "ax_d.set_ylim([m_grid[0], m_grid[-1]])\n",
    "ax_d.set_ylabel(r'$m$')\n",
    "ax_d.text(0.02, 0.95, '(a)', transform=ax_d.transAxes,\n",
    "          fontsize=8, fontweight='bold', va='top', color='white')\n",
    "ax_d.text(0.02, 0.75, r'$m_X$ only', transform=ax_d.transAxes,\n",
    "          fontsize=6, ha='left', va='top', color='white')\n",
    "\n",
    "# Remove x-ticklabels for top axis to avoid clutter\n",
    "plt.setp(ax_d.get_xticklabels(), visible=False)\n",
    "\n",
    "# ============================================================================\n",
    "# BOTTOM PANEL: Joint missingness phase diagram\n",
    "# ============================================================================\n",
    "im_e = ax_e.imshow(Rx2_empirical_e,\n",
    "                   extent=[theta_grid[0], theta_grid[-1], m_grid[0], m_grid[-1]],\n",
    "                   origin='lower', aspect='auto', cmap='viridis', vmin=0, vmax=1)\n",
    "\n",
    "# Phase boundary for joint\n",
    "theta_boundary_joint = [theta_crit_joint(m, alpha_x, alpha_y) for m in m_fine]\n",
    "ax_e.plot(theta_boundary_joint, m_fine, 'r--', linewidth=1.0)\n",
    "\n",
    "ax_e.set_xlim([theta_grid[0], theta_grid[-1]])\n",
    "ax_e.set_ylim([m_grid[0], m_grid[-1]])\n",
    "ax_e.set_xlabel(r'$\\theta$')\n",
    "ax_e.set_ylabel(r'$m$')\n",
    "ax_e.text(0.02, 0.95, '(b)', transform=ax_e.transAxes,\n",
    "          fontsize=8, fontweight='bold', va='top', color='white')\n",
    "ax_e.text(0.02, 0.75, r'$m_X{=}m_Y$', transform=ax_e.transAxes,\n",
    "          fontsize=6, ha='left', va='top', color='white')\n",
    "\n",
    "# Shared colorbar for phase diagrams (on the right)\n",
    "cbar_ax = fig.add_axes([0.76, 0.18, 0.03, 0.75])\n",
    "cbar = fig.colorbar(im_e, cax=cbar_ax)\n",
    "cbar.set_label(r'$R_x^2$', fontsize=7, labelpad=2)\n",
    "cbar.ax.tick_params(labelsize=6)\n",
    "\n",
    "# ============================================================================\n",
    "# Save figure\n",
    "# ============================================================================\n",
    "plt.savefig('../figures/fig2_missingness_effects.pdf', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "print(\"\\n\" + \"=\"*70)\n",
    "print(\"Figure saved: ../figures/fig2_missingness_effects.pdf\")\n",
    "print(\"Dimensions: 3.25 x 2.1 inches (ICML single-column)\")\n",
    "print(\"=\"*70)"
   ]
  }
 ],
 "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
}
