{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cell-0",
   "metadata": {},
   "source": [
    "# Figure 3: Semi-Synthetic Biological Validation\n",
    "\n",
    "Validates phase transition theory using signal directions from real biological data (TCGA, PBMC)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cell-1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.gridspec as gridspec\n",
    "from multiprocessing import Pool\n",
    "from tqdm.notebook import tqdm\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.decomposition import PCA\n",
    "\n",
    "from src import (\n",
    "    ModelParams, whiten_to_identity, pls_svd, compute_overlaps,\n",
    "    theoretical_overlaps, generate_semi_synthetic, apply_mcar\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)\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\", category=UserWarning)\n",
    "warnings.filterwarnings(\"ignore\", category=FutureWarning)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-2",
   "metadata": {},
   "source": [
    "## 1. Load and Preprocess TCGA BRCA Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "cell-3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[cached] ../data/xena/HiSeqV2.gz\n",
      "[cached] ../data/xena/HumanMethylation450.gz\n",
      "TCGA BRCA: 873 paired samples\n",
      "  X (RNA): (873, 20530)\n",
      "  Y (Meth): (873, 485577)\n"
     ]
    }
   ],
   "source": [
    "import requests\n",
    "import gzip\n",
    "\n",
    "XENA_BASE = \"https://tcga.xenahubs.net/download\"\n",
    "DATASETS = {\n",
    "    \"expr\": \"TCGA.BRCA.sampleMap/HiSeqV2.gz\",\n",
    "    \"meth450\": \"TCGA.BRCA.sampleMap/HumanMethylation450.gz\",\n",
    "}\n",
    "\n",
    "def download_xena_file(dataset_path: str, out_dir=\"../data/xena\", chunk_size=1 << 20):\n",
    "    os.makedirs(out_dir, exist_ok=True)\n",
    "    url = f\"{XENA_BASE}/{dataset_path}\"\n",
    "    local_path = os.path.join(out_dir, os.path.basename(dataset_path))\n",
    "    if os.path.exists(local_path):\n",
    "        print(f\"[cached] {local_path}\")\n",
    "        return local_path\n",
    "    print(f\"[download] {url}\")\n",
    "    with requests.get(url, stream=True) as r:\n",
    "        r.raise_for_status()\n",
    "        with open(local_path, \"wb\") as f:\n",
    "            for chunk in r.iter_content(chunk_size=chunk_size):\n",
    "                if chunk:\n",
    "                    f.write(chunk)\n",
    "    return local_path\n",
    "\n",
    "def load_xena_matrix_gz(path_gz: str) -> pd.DataFrame:\n",
    "    df = pd.read_csv(path_gz, sep=\"\\t\", index_col=0, compression=\"gzip\")\n",
    "    return df\n",
    "\n",
    "# Download and load\n",
    "expr_path = download_xena_file(DATASETS[\"expr\"])\n",
    "meth_path = download_xena_file(DATASETS[\"meth450\"])\n",
    "\n",
    "expr = load_xena_matrix_gz(expr_path)  # genes x samples\n",
    "meth = load_xena_matrix_gz(meth_path)  # probes x samples\n",
    "\n",
    "# Transpose to (samples x features)\n",
    "X_raw = expr.T\n",
    "Y_raw = meth.T\n",
    "\n",
    "# Align samples\n",
    "common_samples = X_raw.index.intersection(Y_raw.index)\n",
    "X_raw = X_raw.loc[common_samples]\n",
    "Y_raw = Y_raw.loc[common_samples]\n",
    "\n",
    "print(f\"TCGA BRCA: {len(common_samples)} paired samples\")\n",
    "print(f\"  X (RNA): {X_raw.shape}\")\n",
    "print(f\"  Y (Meth): {Y_raw.shape}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cell-4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Preprocessed TCGA:\n",
      "  X_whitened: (873, 200)\n",
      "  Y_whitened: (873, 200)\n",
      "  X^T X / N check: 0.000000 (should be ~0)\n"
     ]
    }
   ],
   "source": [
    "def preprocess_for_pls(X_df, Y_df, Dx=200, Dy=200):\n",
    "    \"\"\"\n",
    "    Preprocess real data for PLS experiments:\n",
    "    1. Select top-variance features\n",
    "    2. Standardize\n",
    "    3. PCA to target dimension\n",
    "    4. Whiten to satisfy X^T X = N I\n",
    "    \"\"\"\n",
    "    # Drop constant columns and NaNs\n",
    "    X = X_df.dropna(axis=1).values.astype(np.float64)\n",
    "    Y = Y_df.dropna(axis=1).values.astype(np.float64)\n",
    "    \n",
    "    # Standardize\n",
    "    X = StandardScaler().fit_transform(X)\n",
    "    Y = StandardScaler().fit_transform(Y)\n",
    "    \n",
    "    # PCA to reduce dimension\n",
    "    pca_x = PCA(n_components=Dx)\n",
    "    pca_y = PCA(n_components=Dy)\n",
    "    X_pca = pca_x.fit_transform(X)\n",
    "    Y_pca = pca_y.fit_transform(Y)\n",
    "    \n",
    "    # Whiten to satisfy X^T X = N I\n",
    "    X_whitened = whiten_to_identity(X_pca)\n",
    "    Y_whitened = whiten_to_identity(Y_pca)\n",
    "    \n",
    "    return X_whitened, Y_whitened\n",
    "\n",
    "# Preprocess TCGA\n",
    "Dx_tcga, Dy_tcga = 200, 200\n",
    "X_tcga, Y_tcga = preprocess_for_pls(X_raw, Y_raw, Dx=Dx_tcga, Dy=Dy_tcga)\n",
    "N_tcga = X_tcga.shape[0]\n",
    "\n",
    "print(f\"\\nPreprocessed TCGA:\")\n",
    "print(f\"  X_whitened: {X_tcga.shape}\")\n",
    "print(f\"  Y_whitened: {Y_tcga.shape}\")\n",
    "print(f\"  X^T X / N check: {np.linalg.norm(X_tcga.T @ X_tcga / N_tcga - np.eye(Dx_tcga)):.6f} (should be ~0)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cell-5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Extracted biological signal directions (TCGA):\n",
      "  ||u_tcga|| = 1.000000\n",
      "  ||v_tcga|| = 1.000000\n",
      "  Top singular value σ₁ = 0.9957\n"
     ]
    }
   ],
   "source": [
    "# Extract biological signal directions from complete TCGA data\n",
    "u_tcga, v_tcga, sigma1_tcga = pls_svd(X_tcga, Y_tcga, prewhiten=False)  # Already whitened\n",
    "\n",
    "print(f\"\\nExtracted biological signal directions (TCGA):\")\n",
    "print(f\"  ||u_tcga|| = {np.linalg.norm(u_tcga):.6f}\")\n",
    "print(f\"  ||v_tcga|| = {np.linalg.norm(v_tcga):.6f}\")\n",
    "print(f\"  Top singular value σ₁ = {sigma1_tcga:.4f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-6",
   "metadata": {},
   "source": [
    "## 2. Load and Preprocess PBMC Multiome Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cell-7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[cached] ../data/pbmc_multiome_10k/pbmc_granulocyte_sorted_10k_filtered_feature_bc_matrix.h5\n"
     ]
    }
   ],
   "source": [
    "# PBMC Multiome data from 10x Genomics\n",
    "PBMC_URL = \"https://cf.10xgenomics.com/samples/cell-arc/2.0.0/pbmc_granulocyte_sorted_10k/pbmc_granulocyte_sorted_10k_filtered_feature_bc_matrix.h5\"\n",
    "pbmc_dir = \"../data/pbmc_multiome_10k\"\n",
    "pbmc_path = os.path.join(pbmc_dir, \"pbmc_granulocyte_sorted_10k_filtered_feature_bc_matrix.h5\")\n",
    "\n",
    "def download_pbmc_data():\n",
    "    \"\"\"Download PBMC Multiome 10k dataset from 10x Genomics.\"\"\"\n",
    "    os.makedirs(pbmc_dir, exist_ok=True)\n",
    "    print(f\"[download] {PBMC_URL}\")\n",
    "    with requests.get(PBMC_URL, stream=True) as r:\n",
    "        r.raise_for_status()\n",
    "        total_size = int(r.headers.get('content-length', 0))\n",
    "        with open(pbmc_path, 'wb') as f:\n",
    "            downloaded = 0\n",
    "            for chunk in r.iter_content(chunk_size=1 << 20):\n",
    "                if chunk:\n",
    "                    f.write(chunk)\n",
    "                    downloaded += len(chunk)\n",
    "                    if total_size > 0:\n",
    "                        pct = 100 * downloaded / total_size\n",
    "                        print(f\"\\r  Progress: {pct:.1f}%\", end=\"\", flush=True)\n",
    "        print()\n",
    "    print(f\"[saved] {pbmc_path}\")\n",
    "\n",
    "if os.path.exists(pbmc_path):\n",
    "    print(f\"[cached] {pbmc_path}\")\n",
    "else:\n",
    "    download_pbmc_data()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cell-8",
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'muon'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mModuleNotFoundError\u001b[39m                       Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[6]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m \u001b[38;5;28;01mimport\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01mmuon\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mas\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01mmu\u001b[39;00m\n\u001b[32m      2\u001b[39m \u001b[38;5;28;01mimport\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01mscanpy\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mas\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01msc\u001b[39;00m\n\u001b[32m      4\u001b[39m \u001b[38;5;66;03m# Load multiome data\u001b[39;00m\n",
      "\u001b[31mModuleNotFoundError\u001b[39m: No module named 'muon'"
     ]
    }
   ],
   "source": [
    "import muon as mu\n",
    "import scanpy as sc\n",
    "\n",
    "# Load multiome data\n",
    "mdata = mu.read_10x_h5(pbmc_path)\n",
    "\n",
    "# Separate modalities\n",
    "rna = mdata.mod['Gene Expression'] if 'Gene Expression' in mdata.mod else mdata.mod['rna']\n",
    "atac = mdata.mod['Peaks'] if 'Peaks' in mdata.mod else mdata.mod['atac']\n",
    "\n",
    "print(f\"\\nPBMC Multiome loaded:\")\n",
    "print(f\"  RNA: {rna.shape}\")\n",
    "print(f\"  ATAC: {atac.shape}\")\n",
    "\n",
    "# Basic preprocessing\n",
    "sc.pp.filter_cells(rna, min_genes=200)\n",
    "sc.pp.filter_genes(rna, min_cells=3)\n",
    "sc.pp.normalize_total(rna, target_sum=1e4)\n",
    "sc.pp.log1p(rna)\n",
    "sc.pp.highly_variable_genes(rna, n_top_genes=2000)\n",
    "rna = rna[:, rna.var['highly_variable']]\n",
    "\n",
    "# ATAC: TF-IDF + LSI\n",
    "sc.pp.filter_cells(atac, min_genes=200)\n",
    "sc.pp.filter_genes(atac, min_cells=3)\n",
    "\n",
    "# Subsample and align\n",
    "common_cells = rna.obs_names.intersection(atac.obs_names)\n",
    "n_subsample = min(5000, len(common_cells))\n",
    "np.random.seed(42)\n",
    "selected_cells = np.random.choice(common_cells, size=n_subsample, replace=False)\n",
    "\n",
    "X_pbmc_raw = rna[selected_cells].X.toarray() if hasattr(rna[selected_cells].X, 'toarray') else rna[selected_cells].X\n",
    "Y_pbmc_raw = atac[selected_cells].X.toarray() if hasattr(atac[selected_cells].X, 'toarray') else atac[selected_cells].X\n",
    "\n",
    "# PCA + whitening\n",
    "Dx_pbmc, Dy_pbmc = 200, 200\n",
    "X_pbmc_raw = StandardScaler().fit_transform(X_pbmc_raw)\n",
    "Y_pbmc_raw = StandardScaler().fit_transform(Y_pbmc_raw[:, :5000])  # Limit ATAC features\n",
    "\n",
    "pca_x = PCA(n_components=Dx_pbmc)\n",
    "pca_y = PCA(n_components=Dy_pbmc)\n",
    "X_pbmc = whiten_to_identity(pca_x.fit_transform(X_pbmc_raw))\n",
    "Y_pbmc = whiten_to_identity(pca_y.fit_transform(Y_pbmc_raw))\n",
    "N_pbmc = X_pbmc.shape[0]\n",
    "\n",
    "# Extract biological directions\n",
    "u_pbmc, v_pbmc, sigma1_pbmc = pls_svd(X_pbmc, Y_pbmc, prewhiten=False)\n",
    "\n",
    "print(f\"\\nPreprocessed PBMC:\")\n",
    "print(f\"  X_whitened: {X_pbmc.shape}\")\n",
    "print(f\"  Y_whitened: {Y_pbmc.shape}\")\n",
    "print(f\"  Top singular value σ₁ = {sigma1_pbmc:.4f}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-10",
   "metadata": {},
   "source": [
    "## 3. Run Semi-Synthetic Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cell-11",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_semi_synthetic_experiment(\n",
    "    X_whitened, u0, v0, N, Dx, Dy,\n",
    "    theta_values, m_values, n_trials=500,\n",
    "    experiment_name=\"dataset\"\n",
    "):\n",
    "    \"\"\"\n",
    "    Run semi-synthetic validation for a single dataset.\n",
    "    \n",
    "    Returns results for:\n",
    "    - Phase transition (theta sweep at m=0.3)\n",
    "    - Missingness degradation (m sweep at theta=1.5*theta_crit)\n",
    "    - Biological vs random comparison\n",
    "    \n",
    "    Stores raw trial values for flexible statistics computation (std, quantiles).\n",
    "    \"\"\"\n",
    "    results = {\n",
    "        'theta_sweep': [],\n",
    "        'miss_sweep': [],\n",
    "        'bio_vs_random': [],\n",
    "    }\n",
    "    \n",
    "    # Compute theta_crit for reference\n",
    "    alpha_x = N / Dx\n",
    "    alpha_y = N / Dy\n",
    "    m_ref = 0.3\n",
    "    rho_ref = (1 - m_ref) ** 2\n",
    "    theta_crit = 1 / ((alpha_x * alpha_y) ** 0.25 * np.sqrt(rho_ref))\n",
    "    \n",
    "    print(f\"\\n{experiment_name}: N={N}, Dx={Dx}, Dy={Dy}\")\n",
    "    print(f\"  θ_crit (m=0.3) = {theta_crit:.4f}\")\n",
    "    \n",
    "    # --- Experiment A: Theta sweep at fixed missingness ---\n",
    "    print(f\"  Running theta sweep...\")\n",
    "    for theta in tqdm(theta_values, desc=\"  θ sweep\"):\n",
    "        rx2_bio, ry2_bio = [], []\n",
    "        rx2_rand, ry2_rand = [], []\n",
    "        \n",
    "        for trial in range(n_trials):\n",
    "            # Biological directions\n",
    "            X, Y, Sx, Sy = generate_semi_synthetic(\n",
    "                X_whitened, u0, v0, theta, m_ref, m_ref, Dy, seed=trial\n",
    "            )\n",
    "            u_hat, v_hat, _ = pls_svd(X, Y, prewhiten=True)\n",
    "            rx2, ry2 = compute_overlaps(u_hat, v_hat, u0, v0)\n",
    "            rx2_bio.append(rx2)\n",
    "            ry2_bio.append(ry2)\n",
    "            \n",
    "            # Random directions (for comparison)\n",
    "            np.random.seed(trial + 10000)\n",
    "            u0_rand = np.random.randn(Dx)\n",
    "            u0_rand /= np.linalg.norm(u0_rand)\n",
    "            v0_rand = np.random.randn(Dy)\n",
    "            v0_rand /= np.linalg.norm(v0_rand)\n",
    "            \n",
    "            X_r, Y_r, _, _ = generate_semi_synthetic(\n",
    "                X_whitened, u0_rand, v0_rand, theta, m_ref, m_ref, Dy, seed=trial\n",
    "            )\n",
    "            u_hat_r, v_hat_r, _ = pls_svd(X_r, Y_r, prewhiten=True)\n",
    "            rx2_r, ry2_r = compute_overlaps(u_hat_r, v_hat_r, u0_rand, v0_rand)\n",
    "            rx2_rand.append(rx2_r)\n",
    "            ry2_rand.append(ry2_r)\n",
    "        \n",
    "        # Theoretical prediction\n",
    "        params = ModelParams(N=N, Dx=Dx, Dy=Dy, theta=theta, mx=m_ref, my=m_ref)\n",
    "        rx2_theory, ry2_theory = theoretical_overlaps(params)\n",
    "        \n",
    "        # Store raw trial values for flexible statistics\n",
    "        results['theta_sweep'].append({\n",
    "            'theta': theta,\n",
    "            'theta_norm': theta / theta_crit,\n",
    "            'Rx2_bio': np.array(rx2_bio),\n",
    "            'Ry2_bio': np.array(ry2_bio),\n",
    "            'Rx2_rand': np.array(rx2_rand),\n",
    "            'Ry2_rand': np.array(ry2_rand),\n",
    "            'Rx2_theory': rx2_theory,\n",
    "            'Ry2_theory': ry2_theory,\n",
    "        })\n",
    "    \n",
    "    # --- Experiment B: Missingness sweep at fixed theta ---\n",
    "    theta_fixed = 1.5 * theta_crit\n",
    "    print(f\"  Running missingness sweep at θ={theta_fixed:.3f}...\")\n",
    "    \n",
    "    for m in tqdm(m_values, desc=\"  m sweep\"):\n",
    "        rx2_list, ry2_list = [], []\n",
    "        \n",
    "        for trial in range(n_trials):\n",
    "            X, Y, Sx, Sy = generate_semi_synthetic(\n",
    "                X_whitened, u0, v0, theta_fixed, m, m, Dy, seed=trial\n",
    "            )\n",
    "            u_hat, v_hat, _ = pls_svd(X, Y, prewhiten=True)\n",
    "            rx2, ry2 = compute_overlaps(u_hat, v_hat, u0, v0)\n",
    "            rx2_list.append(rx2)\n",
    "            ry2_list.append(ry2)\n",
    "        \n",
    "        # Theoretical prediction\n",
    "        params = ModelParams(N=N, Dx=Dx, Dy=Dy, theta=theta_fixed, mx=m, my=m)\n",
    "        rx2_theory, ry2_theory = theoretical_overlaps(params)\n",
    "        \n",
    "        # Store raw trial values for flexible statistics\n",
    "        results['miss_sweep'].append({\n",
    "            'm': m,\n",
    "            'rho': (1 - m) ** 2,\n",
    "            'Rx2': np.array(rx2_list),\n",
    "            'Ry2': np.array(ry2_list),\n",
    "            'Rx2_theory': rx2_theory,\n",
    "            'Ry2_theory': ry2_theory,\n",
    "        })\n",
    "    \n",
    "    results['theta_crit'] = theta_crit\n",
    "    results['N'] = N\n",
    "    results['Dx'] = Dx\n",
    "    results['Dy'] = Dy\n",
    "    \n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cell-12",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TCGA: θ_crit = 0.6838, θ range: [0.342, 1.709]\n",
      "PBMC: θ_crit = 0.2857, θ range: [0.143, 0.714]\n",
      "m values: [0.  0.1 0.2 0.3 0.4 0.5]\n"
     ]
    }
   ],
   "source": [
    "# Define parameter grids\n",
    "n_trials = 500\n",
    "m_ref = 0.3\n",
    "rho_ref = (1 - m_ref) ** 2\n",
    "\n",
    "# Compute theta_crit for each dataset\n",
    "alpha_x_tcga = N_tcga / Dx_tcga\n",
    "alpha_y_tcga = N_tcga / Dy_tcga\n",
    "theta_crit_tcga = 1 / ((alpha_x_tcga * alpha_y_tcga) ** 0.25 * np.sqrt(rho_ref))\n",
    "\n",
    "alpha_x_pbmc = N_pbmc / Dx_pbmc\n",
    "alpha_y_pbmc = N_pbmc / Dy_pbmc\n",
    "theta_crit_pbmc = 1 / ((alpha_x_pbmc * alpha_y_pbmc) ** 0.25 * np.sqrt(rho_ref))\n",
    "\n",
    "# Create dataset-specific theta values (each spanning 0.5 to 2.5 of their own theta_crit)\n",
    "theta_values_tcga = np.linspace(0.5 * theta_crit_tcga, 2.5 * theta_crit_tcga, 20)\n",
    "theta_values_pbmc = np.linspace(0.5 * theta_crit_pbmc, 2.5 * theta_crit_pbmc, 20)\n",
    "\n",
    "m_values = np.array([0.0, 0.1, 0.2, 0.3, 0.4, 0.5])\n",
    "\n",
    "print(f\"TCGA: θ_crit = {theta_crit_tcga:.4f}, θ range: [{theta_values_tcga[0]:.3f}, {theta_values_tcga[-1]:.3f}]\")\n",
    "print(f\"PBMC: θ_crit = {theta_crit_pbmc:.4f}, θ range: [{theta_values_pbmc[0]:.3f}, {theta_values_pbmc[-1]:.3f}]\")\n",
    "print(f\"m values: {m_values}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cell-13",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading cached results...\n",
      "Done!\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, 'fig3_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",
    "    results_tcga = all_results['tcga']\n",
    "    results_pbmc = all_results['pbmc']\n",
    "    print(\"Done!\")\n",
    "else:\n",
    "    print(\"Running experiments...\")\n",
    "    \n",
    "    # Run TCGA experiments with TCGA-specific theta values\n",
    "    results_tcga = run_semi_synthetic_experiment(\n",
    "        X_tcga, u_tcga, v_tcga, N_tcga, Dx_tcga, Dy_tcga,\n",
    "        theta_values_tcga, m_values, n_trials=n_trials,\n",
    "        experiment_name=\"TCGA BRCA\"\n",
    "    )\n",
    "    \n",
    "    # Run PBMC experiments with PBMC-specific theta values\n",
    "    results_pbmc = run_semi_synthetic_experiment(\n",
    "        X_pbmc, u_pbmc, v_pbmc, N_pbmc, Dx_pbmc, Dy_pbmc,\n",
    "        theta_values_pbmc, m_values, n_trials=n_trials,\n",
    "        experiment_name=\"PBMC\"\n",
    "    )\n",
    "    \n",
    "    # Cache results\n",
    "    all_results = {'tcga': results_tcga, 'pbmc': results_pbmc}\n",
    "    with open(cache_file, 'wb') as f:\n",
    "        pickle.dump(all_results, f)\n",
    "    print(\"\\nResults cached!\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cell-14",
   "metadata": {},
   "source": [
    "## 4. Create Publication Figure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "278ca4f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_stats(values):\n",
    "    \"\"\"Compute mean, std, and quantiles from raw trial values.\"\"\"\n",
    "    return {\n",
    "        'mean': np.mean(values),\n",
    "        'std': np.std(values),\n",
    "        'q05': np.percentile(values, 5),\n",
    "        'q95': np.percentile(values, 95),\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cell-15",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x300 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Figure saved: ../figures/fig3_biological_validation.pdf\n"
     ]
    }
   ],
   "source": [
    "# Figure with ±std error bands\n",
    "fig = plt.figure(figsize=(7.0, 3.0))\n",
    "\n",
    "# Create gridspec with shared axes structure\n",
    "gs = gridspec.GridSpec(2, 3, hspace=0.08, wspace=0.08,\n",
    "                       left=0.12, right=0.98, bottom=0.12, top=0.88)\n",
    "\n",
    "datasets = [\n",
    "    ('TCGA BRCA', results_tcga),\n",
    "    ('PBMC', results_pbmc),\n",
    "]\n",
    "\n",
    "# Column titles\n",
    "col_titles = ['Phase Transition', 'Missingness Degradation', 'Biological vs Random']\n",
    "\n",
    "# Store axes for sharing\n",
    "axes = []\n",
    "\n",
    "# Fixed x-axis range for theta_norm (both datasets now span 0.5 to 2.5)\n",
    "xlim_theta = [0.4, 2.6]\n",
    "\n",
    "for row, (name, results) in enumerate(datasets):\n",
    "    ax_a = fig.add_subplot(gs[row, 0])\n",
    "    ax_b = fig.add_subplot(gs[row, 1])\n",
    "    ax_c = fig.add_subplot(gs[row, 2])\n",
    "    axes.append([ax_a, ax_b, ax_c])\n",
    "    \n",
    "    theta_crit = results['theta_crit']\n",
    "    \n",
    "    # --- Panel A/D: Phase transition (θ sweep) ---\n",
    "    theta_sweep = results['theta_sweep']\n",
    "    theta_norm = [r['theta_norm'] for r in theta_sweep]\n",
    "    \n",
    "    # Compute stats from raw values\n",
    "    rx2_bio_stats = [compute_stats(r['Rx2_bio']) for r in theta_sweep]\n",
    "    ry2_bio_stats = [compute_stats(r['Ry2_bio']) for r in theta_sweep]\n",
    "    rx2_rand_stats = [compute_stats(r['Rx2_rand']) for r in theta_sweep]\n",
    "    ry2_rand_stats = [compute_stats(r['Ry2_rand']) for r in theta_sweep]\n",
    "    \n",
    "    # R_x² - biological\n",
    "    ax_a.plot(theta_norm, [s['mean'] for s in rx2_bio_stats],\n",
    "              'o-', markersize=3, linewidth=0.8, color='C0', label=r'$R_x^2$')\n",
    "    ax_a.fill_between(theta_norm,\n",
    "                      [s['mean'] - s['std'] for s in rx2_bio_stats],\n",
    "                      [s['mean'] + s['std'] for s in rx2_bio_stats],\n",
    "                      color='C0', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    # R_y² - biological\n",
    "    ax_a.plot(theta_norm, [s['mean'] for s in ry2_bio_stats],\n",
    "              's-', markersize=3, linewidth=0.8, color='C1', label=r'$R_y^2$')\n",
    "    ax_a.fill_between(theta_norm,\n",
    "                      [s['mean'] - s['std'] for s in ry2_bio_stats],\n",
    "                      [s['mean'] + s['std'] for s in ry2_bio_stats],\n",
    "                      color='C1', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    # Theory\n",
    "    ax_a.plot(theta_norm, [r['Rx2_theory'] for r in theta_sweep],\n",
    "              'k--', linewidth=1.2, label='Theory')\n",
    "    ax_a.plot(theta_norm, [r['Ry2_theory'] for r in theta_sweep],\n",
    "              'k--', linewidth=1.2)\n",
    "    \n",
    "    ax_a.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7)\n",
    "    ax_a.set_ylim([-0.05, 1.05])\n",
    "    ax_a.set_xlim(xlim_theta)\n",
    "    \n",
    "    # --- Panel B/E: Missingness degradation ---\n",
    "    miss_sweep = results['miss_sweep']\n",
    "    m_vals = [r['m'] for r in miss_sweep]\n",
    "    \n",
    "    # Compute stats from raw values\n",
    "    rx2_miss_stats = [compute_stats(r['Rx2']) for r in miss_sweep]\n",
    "    ry2_miss_stats = [compute_stats(r['Ry2']) for r in miss_sweep]\n",
    "    \n",
    "    ax_b.plot(m_vals, [s['mean'] for s in rx2_miss_stats],\n",
    "              'o-', markersize=4, linewidth=1, color='C0', label=r'$R_x^2$')\n",
    "    ax_b.fill_between(m_vals,\n",
    "                      [s['mean'] - s['std'] for s in rx2_miss_stats],\n",
    "                      [s['mean'] + s['std'] for s in rx2_miss_stats],\n",
    "                      color='C0', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    ax_b.plot(m_vals, [s['mean'] for s in ry2_miss_stats],\n",
    "              's-', markersize=4, linewidth=1, color='C1', label=r'$R_y^2$')\n",
    "    ax_b.fill_between(m_vals,\n",
    "                      [s['mean'] - s['std'] for s in ry2_miss_stats],\n",
    "                      [s['mean'] + s['std'] for s in ry2_miss_stats],\n",
    "                      color='C1', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    ax_b.plot(m_vals, [r['Rx2_theory'] for r in miss_sweep],\n",
    "              'k--', linewidth=1.2, label='Theory')\n",
    "    ax_b.plot(m_vals, [r['Ry2_theory'] for r in miss_sweep],\n",
    "              'k--', linewidth=1.2)\n",
    "    \n",
    "    ax_b.set_ylim([-0.05, 1.05])\n",
    "    \n",
    "    # Add theta annotation in upper right\n",
    "    ax_b.text(0.95, 0.95, r'$\\theta = 1.5\\theta_{\\mathrm{crit}}$',\n",
    "              transform=ax_b.transAxes, fontsize=7, ha='right', va='top')\n",
    "    \n",
    "    # --- Panel C/F: Biological vs Random directions ---\n",
    "    # Biological\n",
    "    ax_c.plot(theta_norm, [s['mean'] for s in rx2_bio_stats],\n",
    "              'o-', markersize=3, linewidth=0.8, color='C0', label='Biological')\n",
    "    ax_c.fill_between(theta_norm,\n",
    "                      [s['mean'] - s['std'] for s in rx2_bio_stats],\n",
    "                      [s['mean'] + s['std'] for s in rx2_bio_stats],\n",
    "                      color='C0', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    # Random\n",
    "    ax_c.plot(theta_norm, [s['mean'] for s in rx2_rand_stats],\n",
    "              '^-', markersize=3, linewidth=0.8, color='C2', label='Random')\n",
    "    ax_c.fill_between(theta_norm,\n",
    "                      [s['mean'] - s['std'] for s in rx2_rand_stats],\n",
    "                      [s['mean'] + s['std'] for s in rx2_rand_stats],\n",
    "                      color='C2', alpha=0.2, linewidth=0)\n",
    "    \n",
    "    # Theory\n",
    "    ax_c.plot(theta_norm, [r['Rx2_theory'] for r in theta_sweep],\n",
    "              'k--', linewidth=1.2, label='Theory')\n",
    "    \n",
    "    ax_c.axvline(1.0, color='red', linestyle=':', linewidth=1.5, alpha=0.7)\n",
    "    ax_c.set_ylim([-0.05, 1.05])\n",
    "    ax_c.set_xlim(xlim_theta)\n",
    "    \n",
    "    # Dataset name on the left (rotated 90 degrees)\n",
    "    ax_a.text(-0.32, 0.5, name, transform=ax_a.transAxes,\n",
    "              fontsize=9, fontweight='bold', va='center', ha='center',\n",
    "              rotation=90)\n",
    "    \n",
    "    # Handle x-axis labels (only bottom row)\n",
    "    if row == 0:\n",
    "        # Top row: no x-axis labels\n",
    "        ax_a.tick_params(labelbottom=False)\n",
    "        ax_b.tick_params(labelbottom=False)\n",
    "        ax_c.tick_params(labelbottom=False)\n",
    "\n",
    "        ax_a.legend(loc='lower right', # bbox_to_anchor=(0.5, -0.45),\n",
    "                   ncol=1, frameon=False, fontsize=7, labelspacing=0.05)\n",
    "        ax_b.legend(loc='lower left', # bbox_to_anchor=(0.5, -0.45),\n",
    "                   ncol=1, frameon=False, fontsize=7, labelspacing=0.05)\n",
    "        ax_c.legend(loc='lower right', # bbox_to_anchor=(0.5, -0.45),\n",
    "                   ncol=1, frameon=False, fontsize=7, labelspacing=0.20)\n",
    "\n",
    "\n",
    "    else:\n",
    "        # Bottom row: add x-axis labels\n",
    "        ax_a.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
    "        ax_b.set_xlabel(r'Missingness $m$')\n",
    "        ax_c.set_xlabel(r'$\\theta / \\theta_{\\mathrm{crit}}$')\n",
    "    \n",
    "    # Handle y-axis labels (only left column shows ticks)\n",
    "    ax_b.tick_params(labelleft=False)\n",
    "    ax_c.tick_params(labelleft=False)\n",
    "\n",
    "# Add column titles at top\n",
    "for col, title in enumerate(col_titles):\n",
    "    axes[0][col].set_title(title, fontsize=9, fontweight='bold', pad=8)\n",
    "\n",
    "# Add y-axis labels rotated at top of y-axis for each column\n",
    "# Column 1 (a/d): R²\n",
    "axes[0][0].text(-0.20, 0.90, r'$R^2$', transform=axes[0][0].transAxes,\n",
    "                fontsize=9, ha='center', va='bottom', rotation=0)\n",
    "axes[1][0].text(-0.20, 0.90, r'$R^2$', transform=axes[1][0].transAxes,\n",
    "                fontsize=9, ha='center', va='bottom', rotation=0)\n",
    "\n",
    "# Column 3 (c/f): R_x²\n",
    "axes[0][2].text(-0.10, 0.90, r'$R_x^2$', transform=axes[0][2].transAxes,\n",
    "                fontsize=9, ha='center', va='bottom', rotation=0)\n",
    "axes[1][2].text(-0.10, 0.90, r'$R_x^2$', transform=axes[1][2].transAxes,\n",
    "                fontsize=9, ha='center', va='bottom', rotation=0)\n",
    "\n",
    "# Add panel labels to the right of y-axis (inside plot area, top-left)\n",
    "labels = ['(a)', '(b)', '(c)', '(d)', '(e)', '(f)']\n",
    "for i, row_axes in enumerate(axes):\n",
    "    for j, ax in enumerate(row_axes):\n",
    "        label_idx = i * 3 + j\n",
    "        ax.text(0.03, 0.97, labels[label_idx], transform=ax.transAxes,\n",
    "                fontsize=10, fontweight='bold', va='top', ha='left')\n",
    "\n",
    "plt.savefig('../figures/fig3_biological_validation.pdf', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "print(\"\\nFigure saved: ../figures/fig3_biological_validation.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ef3f47ba",
   "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
}
