{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"provenance":[],"authorship_tag":"ABX9TyMZs+5mpQoM1EIWPEB3OLPh"},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"code","execution_count":1,"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":0},"id":"LrNz5GDLbPzv","outputId":"96d65795-ddfb-41be-a1b8-5551125a28e4","executionInfo":{"status":"ok","timestamp":1769577183556,"user_tz":300,"elapsed":378487,"user":{"displayName":"D K","userId":"02556183042422178006"}}},"outputs":[{"output_type":"stream","name":"stdout","text":["Mounted at /content/drive\n","Working Directory: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline\n","Loading empirical data from: emp_app.csv...\n","Loading semi-synthetic components from: semi-syn data grf.csv...\n","Loading ground truth h*(t) from: h_star_grf_empapp.csv...\n","Data loading complete.\n","n=4024, grid_size=47\n","\n","🚀 Running T-only Laplace KRR baseline for K=100 runs ...\n","    Fixed ell_t=3000.0, Nyström m=700, beta in [0.05, 80.0]\n","    SciPy minimize_scalar available: True\n","--- Run 1/100 (seed=1) ---\n","  MISE: 3.967257 | beta*: 4.11846\n","--- Run 2/100 (seed=2) ---\n","  MISE: 0.984845 | beta*: 4.77785\n","--- Run 3/100 (seed=3) ---\n","  MISE: 0.571365 | beta*: 5.76858\n","--- Run 4/100 (seed=4) ---\n","  MISE: 1.205090 | beta*: 1.7436\n","--- Run 5/100 (seed=5) ---\n","  MISE: 2.367297 | beta*: 4.38487\n","--- Run 6/100 (seed=6) ---\n","  MISE: 1.050593 | beta*: 3.27025\n","--- Run 7/100 (seed=7) ---\n","  MISE: 1.470014 | beta*: 3.4569\n","--- Run 8/100 (seed=8) ---\n","  MISE: 0.365791 | beta*: 6.71189\n","--- Run 9/100 (seed=9) ---\n","  MISE: 1.087227 | beta*: 5.99082\n","--- Run 10/100 (seed=10) ---\n","  MISE: 2.569538 | beta*: 5.3118\n","--- Run 11/100 (seed=11) ---\n","  MISE: 3.141789 | beta*: 6.84065\n","--- Run 12/100 (seed=12) ---\n","  MISE: 0.913712 | beta*: 2.52603\n","--- Run 13/100 (seed=13) ---\n","  MISE: 1.495655 | beta*: 4.11099\n","--- Run 14/100 (seed=14) ---\n","  MISE: 0.977810 | beta*: 5.44483\n","--- Run 15/100 (seed=15) ---\n","  MISE: 1.608360 | beta*: 5.31328\n","--- Run 16/100 (seed=16) ---\n","  MISE: 0.655300 | beta*: 7.23717\n","--- Run 17/100 (seed=17) ---\n","  MISE: 1.768657 | beta*: 6.60529\n","--- Run 18/100 (seed=18) ---\n","  MISE: 1.235382 | beta*: 2.74306\n","--- Run 19/100 (seed=19) ---\n","  MISE: 1.544871 | beta*: 4.86882\n","--- Run 20/100 (seed=20) ---\n","  MISE: 0.750233 | beta*: 4.71078\n","--- Run 21/100 (seed=21) ---\n","  MISE: 2.620236 | beta*: 5.68277\n","--- Run 22/100 (seed=22) ---\n","  MISE: 6.458253 | beta*: 1.68665\n","--- Run 23/100 (seed=23) ---\n","  MISE: 3.336790 | beta*: 6.02914\n","--- Run 24/100 (seed=24) ---\n","  MISE: 1.049742 | beta*: 5.03518\n","--- Run 25/100 (seed=25) ---\n","  MISE: 1.628197 | beta*: 5.36527\n","--- Run 26/100 (seed=26) ---\n","  MISE: 1.000476 | beta*: 5.83161\n","--- Run 27/100 (seed=27) ---\n","  MISE: 0.691654 | beta*: 7.03701\n","--- Run 28/100 (seed=28) ---\n","  MISE: 3.356158 | beta*: 0.553467\n","--- Run 29/100 (seed=29) ---\n","  MISE: 1.415677 | beta*: 5.54926\n","--- Run 30/100 (seed=30) ---\n","  MISE: 3.495270 | beta*: 4.14786\n","--- Run 31/100 (seed=31) ---\n","  MISE: 1.252192 | beta*: 5.61236\n","--- Run 32/100 (seed=32) ---\n","  MISE: 0.297935 | beta*: 6.10918\n","--- Run 33/100 (seed=33) ---\n","  MISE: 2.528014 | beta*: 6.77416\n","--- Run 34/100 (seed=34) ---\n","  MISE: 2.727404 | beta*: 1.74527\n","--- Run 35/100 (seed=35) ---\n","  MISE: 2.635871 | beta*: 5.1569\n","--- Run 36/100 (seed=36) ---\n","  MISE: 1.405484 | beta*: 4.4852\n","--- Run 37/100 (seed=37) ---\n","  MISE: 0.348209 | beta*: 4.50004\n","--- Run 38/100 (seed=38) ---\n","  MISE: 0.463495 | beta*: 4.97434\n","--- Run 39/100 (seed=39) ---\n","  MISE: 1.607931 | beta*: 3.01374\n","--- Run 40/100 (seed=40) ---\n","  MISE: 1.611914 | beta*: 3.50739\n","--- Run 41/100 (seed=41) ---\n","  MISE: 0.563225 | beta*: 4.19118\n","--- Run 42/100 (seed=42) ---\n","  MISE: 1.700887 | beta*: 6.76787\n","--- Run 43/100 (seed=43) ---\n","  MISE: 0.958601 | beta*: 6.28042\n","--- Run 44/100 (seed=44) ---\n","  MISE: 3.360250 | beta*: 4.27732\n","--- Run 45/100 (seed=45) ---\n","  MISE: 0.675978 | beta*: 6.35955\n","--- Run 46/100 (seed=46) ---\n","  MISE: 1.069213 | beta*: 5.55288\n","--- Run 47/100 (seed=47) ---\n","  MISE: 0.997897 | beta*: 4.19027\n","--- Run 48/100 (seed=48) ---\n","  MISE: 2.952185 | beta*: 4.7817\n","--- Run 49/100 (seed=49) ---\n","  MISE: 1.191582 | beta*: 3.87135\n","--- Run 50/100 (seed=50) ---\n","  MISE: 1.070660 | beta*: 5.40476\n","--- Run 51/100 (seed=51) ---\n","  MISE: 2.739655 | beta*: 3.77945\n","--- Run 52/100 (seed=52) ---\n","  MISE: 1.393355 | beta*: 5.94089\n","--- Run 53/100 (seed=53) ---\n","  MISE: 1.121173 | beta*: 5.5297\n","--- Run 54/100 (seed=54) ---\n","  MISE: 2.531487 | beta*: 4.44546\n","--- Run 55/100 (seed=55) ---\n","  MISE: 5.946756 | beta*: 1.28192\n","--- Run 56/100 (seed=56) ---\n","  MISE: 1.348511 | beta*: 5.7686\n","--- Run 57/100 (seed=57) ---\n","  MISE: 1.038925 | beta*: 2.51783\n","--- Run 58/100 (seed=58) ---\n","  MISE: 0.836692 | beta*: 5.63425\n","--- Run 59/100 (seed=59) ---\n","  MISE: 0.729236 | beta*: 3.68499\n","--- Run 60/100 (seed=60) ---\n","  MISE: 1.966245 | beta*: 5.00754\n","--- Run 61/100 (seed=61) ---\n","  MISE: 6.747673 | beta*: 2.56806\n","--- Run 62/100 (seed=62) ---\n","  MISE: 3.615418 | beta*: 4.6818\n","--- Run 63/100 (seed=63) ---\n","  MISE: 1.228633 | beta*: 6.28561\n","--- Run 64/100 (seed=64) ---\n","  MISE: 0.894186 | beta*: 3.35541\n","--- Run 65/100 (seed=65) ---\n","  MISE: 1.535945 | beta*: 6.1801\n","--- Run 66/100 (seed=66) ---\n","  MISE: 1.102388 | beta*: 4.55561\n","--- Run 67/100 (seed=67) ---\n","  MISE: 0.769668 | beta*: 4.7119\n","--- Run 68/100 (seed=68) ---\n","  MISE: 1.919343 | beta*: 4.04979\n","--- Run 69/100 (seed=69) ---\n","  MISE: 0.818027 | beta*: 7.01357\n","--- Run 70/100 (seed=70) ---\n","  MISE: 2.789672 | beta*: 2.64159\n","--- Run 71/100 (seed=71) ---\n","  MISE: 0.433163 | beta*: 6.54178\n","--- Run 72/100 (seed=72) ---\n","  MISE: 1.239050 | beta*: 6.90856\n","--- Run 73/100 (seed=73) ---\n","  MISE: 1.717024 | beta*: 1.90006\n","--- Run 74/100 (seed=74) ---\n","  MISE: 0.728003 | beta*: 3.90278\n","--- Run 75/100 (seed=75) ---\n","  MISE: 1.093978 | beta*: 6.5116\n","--- Run 76/100 (seed=76) ---\n","  MISE: 0.123144 | beta*: 5.79209\n","--- Run 77/100 (seed=77) ---\n","  MISE: 0.503999 | beta*: 6.07375\n","--- Run 78/100 (seed=78) ---\n","  MISE: 1.111929 | beta*: 5.86008\n","--- Run 79/100 (seed=79) ---\n","  MISE: 1.185643 | beta*: 5.46639\n","--- Run 80/100 (seed=80) ---\n","  MISE: 1.380153 | beta*: 4.14183\n","--- Run 81/100 (seed=81) ---\n","  MISE: 0.380951 | beta*: 6.13632\n","--- Run 82/100 (seed=82) ---\n","  MISE: 0.260521 | beta*: 7.03747\n","--- Run 83/100 (seed=83) ---\n","  MISE: 3.249782 | beta*: 0.844072\n","--- Run 84/100 (seed=84) ---\n","  MISE: 2.998542 | beta*: 4.90313\n","--- Run 85/100 (seed=85) ---\n","  MISE: 1.121311 | beta*: 5.80934\n","--- Run 86/100 (seed=86) ---\n","  MISE: 0.770918 | beta*: 5.24424\n","--- Run 87/100 (seed=87) ---\n","  MISE: 1.029196 | beta*: 5.78286\n","--- Run 88/100 (seed=88) ---\n","  MISE: 3.647641 | beta*: 3.07939\n","--- Run 89/100 (seed=89) ---\n","  MISE: 0.731959 | beta*: 4.67027\n","--- Run 90/100 (seed=90) ---\n","  MISE: 1.096599 | beta*: 6.66175\n","--- Run 91/100 (seed=91) ---\n","  MISE: 2.368552 | beta*: 3.38391\n","--- Run 92/100 (seed=92) ---\n","  MISE: 1.626782 | beta*: 4.16158\n","--- Run 93/100 (seed=93) ---\n","  MISE: 2.157247 | beta*: 4.42505\n","--- Run 94/100 (seed=94) ---\n","  MISE: 0.695214 | beta*: 6.21927\n","--- Run 95/100 (seed=95) ---\n","  MISE: 4.777130 | beta*: 1.52733\n","--- Run 96/100 (seed=96) ---\n","  MISE: 2.429844 | beta*: 2.90607\n","--- Run 97/100 (seed=97) ---\n","  MISE: 0.965043 | beta*: 3.39367\n","--- Run 98/100 (seed=98) ---\n","  MISE: 1.278237 | beta*: 5.74097\n","--- Run 99/100 (seed=99) ---\n","  MISE: 1.532258 | beta*: 7.24735\n","--- Run 100/100 (seed=100) ---\n","  MISE: 1.791731 | beta*: 2.3197\n","\n","====================================\n","Simulation Summary (K=100)\n","====================================\n","Mean MISE : 1.697007\n","Std  MISE : 1.264613\n","SE   MISE : 0.126461\n","------------------------------------\n","Mean beta*: 4.74637\n","Std  beta*: 1.58169\n","SE   beta*: 0.158169\n","\n","Saved curves to: /content/drive/MyDrive/Colab Notebooks/CTE_Baseline/KRR_methods/Results/direct_semi-real_seeds_1-100.csv\n"]},{"output_type":"stream","name":"stderr","text":["/tmp/ipython-input-3851760453.py:333: PerformanceWarning: DataFrame is highly fragmented.  This is usually the result of calling `frame.insert` many times, which has poor performance.  Consider joining all columns at once using pd.concat(axis=1) instead. To get a de-fragmented frame, use `newframe = frame.copy()`\n","  df_out[f\"h_hat_seed_{seed}\"] = results[\"curves_mat\"][i, :]\n","/tmp/ipython-input-3851760453.py:335: PerformanceWarning: DataFrame is highly fragmented.  This is usually the result of calling `frame.insert` many times, which has poor performance.  Consider joining all columns at once using pd.concat(axis=1) instead. To get a de-fragmented frame, use `newframe = frame.copy()`\n","  df_out[\"mean_h_hat\"] = results[\"mean_curve\"]\n","/tmp/ipython-input-3851760453.py:336: PerformanceWarning: DataFrame is highly fragmented.  This is usually the result of calling `frame.insert` many times, which has poor performance.  Consider joining all columns at once using pd.concat(axis=1) instead. To get a de-fragmented frame, use `newframe = frame.copy()`\n","  df_out[\"se_h_hat\"] = results[\"se_curve\"]\n","/tmp/ipython-input-3851760453.py:337: PerformanceWarning: DataFrame is highly fragmented.  This is usually the result of calling `frame.insert` many times, which has poor performance.  Consider joining all columns at once using pd.concat(axis=1) instead. To get a de-fragmented frame, use `newframe = frame.copy()`\n","  df_out[\"h_star\"] = H_STAR_VALS\n"]},{"output_type":"display_data","data":{"text/plain":["<Figure size 640x480 with 1 Axes>"],"image/png":"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c+ZM2rdvT7NmzRg9ejTBwcFcvHiRVatWcfjwYQCmTZvG5s2bad26Nc888wz16tUjLi6OgwcPsmHDhkIPsc3h4ODAqlWr6NSpE0899RSurq7069fvvq8ZMWIE7777Lh9//DEDBgwosIzXXnuNQYMGsXDhwlydr4vDwsKC7777jl69elG/fn1GjhxJ1apVuXr1Kps3b8bFxSXfKe6Lq3nz5syZM4cpU6ZQs2ZNvL296dKlS7H7sIwZM4aEhAQ6duxI1apViYmJYfHixZw6dYrPPvvMqBnjzTff5LfffqNz586MGzeOpKQkpk+fTsOGDRk5cqThvICAAMaPH8/06dPJzMykZcuWLF++nO3bt7N48WKjZtnCXvPq1avUrVuX4cOHGy1NMH36dPr160f37t157LHHOHbsGLNmzeLpp582GlZ98eJFgoODc72+MO73s1ncPiwrV67kyJEjgJqMHT16lClTpgDQr18/wz9DjzzyCA888AAjR47kxIkThplus7OzjZrJi/JeiFKk0egkYSaKM9Pthg0blHbt2in29vaKi4uL0rdvX+XEiRNG5+QMa75x44bR/ryGm95vptv69esrFhYWypUrVwoVW0HDTX/88UdFURRlxYoVSqNGjRQ7OzulevXqyscff6zMnz8/z9j69OmjrFu3TmnUqJFia2urhIaGGs2EqSh5D2s+ceKEEh4erjg5OSmenp7KM888oxw5ciTPIbzHjh1TBg4cqLi5uSl2dnZKnTp1lHfeecfonOvXrytjx45VAgMDFWtra8XX11fp2rWr8u233xb4vvx3NtEcMTExSs2aNRU7OztD7OQx022O9957z+g+85vpVlEUJTs7WwkJCVFCQkKMZlvNS17vSX4OHTqkPPTQQ4qHh4dia2urBAUFKYMHD1Y2btxoOKe0hjXHxMQoffr0UZydnRWgxLPe/vzzz0p4eLji4+OjWFlZKe7u7kp4eLjy559/5nn+sWPHlO7duysODg6Km5ubMmTIECUmJibXednZ2cr//vc/JSgoSLGxsVHq16+v/PTTT8W+Zs7vUV6/l8uWLVOaNGmi2NraKgEBAcrbb7+tZGRkGJ0TERFhNKT6forys1lcw4cPz/dvwn9/7uLi4pRRo0YpHh4eioODg9KpU6c8f74VpXDvhSg9OkUpoPejEBpq2rQpVapUYePGjZqUX716dRo0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\n"},"metadata":{}}],"source":["# -*- coding: utf-8 -*-\n","\"\"\"\n","Semi-synthetic Job Corps experiment (T-only baseline)\n","\n","Goal:\n","- For each simulation run k = 1..K:\n","  1) Generate semi-synthetic outcomes Y_syn = mu_hat + e*g (new e per seed)\n","  2) Permute (X, T, Y) consistently\n","  3) Ignore X entirely, fit KRR of Y on T with Laplace kernel, fixed ell_t=3000\n","  4) Evaluate h_hat(t) on T_GRID and compute MISE vs H_STAR_VALS\n","- Output mean MISE and its standard error (SE), plus mean/se curve\n","\n","Notes:\n","- Laplace kernel: k(t,t') = exp(-|t-t'|/ell_t)  (Matérn nu=0.5)\n","- Uses Nyström features + LOOCV to choose ridge beta within [BETA_MIN, BETA_MAX]\n","  (fast enough for many runs; mirrors the LOOCV spirit in your pipeline).\n","\"\"\"\n","\n","import sys\n","import pathlib\n","import numpy as np\n","import pandas as pd\n","import matplotlib.pyplot as plt\n","\n","# Optional: SciPy for continuous 1D optimization of beta via bounded minimization.\n","# If SciPy is not available, we fall back to a log-grid search.\n","try:\n","    from scipy.optimize import minimize_scalar\n","    _HAVE_SCIPY = True\n","except Exception:\n","    _HAVE_SCIPY = False\n","\n","\n","# ----------------------------------------------------------------------\n","# Environment Setup (Colab-friendly)\n","# ----------------------------------------------------------------------\n","try:\n","    from google.colab import drive\n","    drive.mount(\"/content/drive\")\n","    BASE_DIR = pathlib.Path(\"/content/drive/MyDrive/Colab Notebooks/CTE_Baseline\")\n","except Exception:\n","    BASE_DIR = pathlib.Path(\".\").resolve()\n","\n","sys.path.append(str(BASE_DIR))\n","\n","# Project imports (must exist under BASE_DIR/KRR_methods/...)\n","from KRR_methods.data_jobcorps import load_jobcorps_data, gen_semi_y\n","\n","print(f\"Working Directory: {BASE_DIR}\")\n","\n","\n","# ----------------------------------------------------------------------\n","# Configuration\n","# ----------------------------------------------------------------------\n","EMP_DIR = BASE_DIR / \"DML_methods\" / \"Data_and_Results\"\n","DATA_FILE = EMP_DIR / \"emp_app.csv\"\n","SEMI_SYN_FILE = EMP_DIR / \"semi-syn data grf.csv\"\n","H_STAR_FILE = EMP_DIR / \"h_star_grf_empapp.csv\"\n","\n","RESULTS_DIR = BASE_DIR / \"KRR_methods\" / \"Results\"\n","RESULTS_DIR.mkdir(parents=True, exist_ok=True)\n","\n","# Simulation settings\n","K_RUNS = 100          # <-- change this\n","FIRST_SEED = 1       # <-- change this\n","\n","# T-only baseline hyperparameters\n","ELL_T_FIXED = 3000.0     # fixed length-scale as requested\n","NYSTROM_M_T = 700        # landmarks (speed/accuracy trade-off)\n","BETA_MIN = 0.05\n","BETA_MAX = 80.0\n","\n","# Numerical stability\n","JITTER = 1e-8\n","\n","\n","# ----------------------------------------------------------------------\n","# Data Loading\n","# ----------------------------------------------------------------------\n","X, T, MU_HAT, G_FUNC, T_GRID, H_STAR_VALS = load_jobcorps_data(\n","    data_file=DATA_FILE,\n","    semi_syn_file=SEMI_SYN_FILE,\n","    h_star_file=H_STAR_FILE,\n",")\n","\n","# Convert to convenient types\n","T = T.reset_index(drop=True) if hasattr(T, \"reset_index\") else T\n","X = X.reset_index(drop=True) if hasattr(X, \"reset_index\") else X\n","\n","T_GRID = np.asarray(T_GRID, dtype=float).ravel()\n","H_STAR_VALS = np.asarray(H_STAR_VALS, dtype=float).ravel()\n","\n","print(\"Data loading complete.\")\n","print(f\"n={len(T)}, grid_size={len(T_GRID)}\")\n","\n","\n","# ----------------------------------------------------------------------\n","# T-only KRR (Nyström + LOOCV over beta) with Laplace kernel\n","# ----------------------------------------------------------------------\n","def laplace_kernel_1d(t1: np.ndarray, t2: np.ndarray, ell: float) -> np.ndarray:\n","    \"\"\"\n","    Laplace kernel in 1D:\n","      k(t, t') = exp(-|t - t'| / ell)\n","    \"\"\"\n","    t1 = np.asarray(t1, dtype=float).reshape(-1, 1)\n","    t2 = np.asarray(t2, dtype=float).reshape(-1, 1)\n","    r = np.abs(t1 - t2.T)\n","    return np.exp(-r / float(ell))\n","\n","\n","def _build_nystrom_features_laplace(T_train: np.ndarray, ell_t: float, m: int, rng: np.random.RandomState):\n","    \"\"\"\n","    Build Nyström features Phi for Laplace kernel using m landmarks.\n","    Returns (Phi, phi_eval_fn) where:\n","      - Phi is (n, m_eff)\n","      - phi_eval_fn(T_new) returns (len(T_new), m_eff)\n","    \"\"\"\n","    T_train = np.asarray(T_train, dtype=float).ravel()\n","    n = len(T_train)\n","    m_eff = int(min(m, n))\n","\n","    idx = rng.choice(n, size=m_eff, replace=False)\n","    Tm = T_train[idx]\n","\n","    K_mm = laplace_kernel_1d(Tm, Tm, ell=ell_t)\n","    K_mm = 0.5 * (K_mm + K_mm.T)\n","    K_mm += JITTER * np.eye(m_eff)\n","\n","    K_nm = laplace_kernel_1d(T_train, Tm, ell=ell_t)\n","\n","    evals, evecs = np.linalg.eigh(K_mm)\n","    evals = np.maximum(evals, 1e-12)\n","    inv_sqrt = 1.0 / np.sqrt(evals)\n","\n","    # Standard Nyström features with sqrt(m/n) scaling\n","    scale = np.sqrt(m_eff / float(n))\n","    Phi = scale * (K_nm @ (evecs * inv_sqrt))\n","\n","    def phi_eval(T_new: np.ndarray) -> np.ndarray:\n","        T_new = np.asarray(T_new, dtype=float).ravel()\n","        K_new_m = laplace_kernel_1d(T_new, Tm, ell=ell_t)\n","        return scale * (K_new_m @ (evecs * inv_sqrt))\n","\n","    return Phi, phi_eval\n","\n","\n","def _loocv_beta_optimize_svd(Phi: np.ndarray, Y: np.ndarray, beta_min: float, beta_max: float) -> float:\n","    \"\"\"\n","    Given features Phi (n x r), choose beta by minimizing LOOCV MSE using\n","    the efficient SVD-based formula.\n","    \"\"\"\n","    Y = np.asarray(Y, dtype=float).ravel()\n","    U, s, Vt = np.linalg.svd(Phi, full_matrices=False)\n","\n","    Uy = U.T @ Y\n","    U_sq = U ** 2\n","    s2 = s ** 2\n","\n","    def loocv_mse(beta: float) -> float:\n","        if beta <= 0:\n","            return float(\"inf\")\n","        shrink = s2 / (s2 + beta)\n","        y_hat = U @ (shrink * Uy)\n","        diagS = U_sq @ shrink\n","        eps = 1e-12\n","        resid = Y - y_hat\n","        loo_resid = resid / (1.0 - diagS + eps)\n","        return float(np.mean(loo_resid ** 2))\n","\n","    lower = max(float(beta_min), 1e-8)\n","    upper = max(float(beta_max), lower * 1.0001)\n","\n","    if _HAVE_SCIPY:\n","        res = minimize_scalar(loocv_mse, bounds=(lower, upper), method=\"bounded\")\n","        return float(res.x)\n","\n","    # Fallback: log-grid search\n","    grid = np.logspace(np.log10(lower), np.log10(upper), 30)\n","    vals = [loocv_mse(b) for b in grid]\n","    return float(grid[int(np.argmin(vals))])\n","\n","\n","def estimate_h_grid_t_only_laplace_fixed_ell(\n","    T_train: np.ndarray,\n","    Y_train: np.ndarray,\n","    t_grid: np.ndarray,\n","    *,\n","    ell_t: float = 3000.0,\n","    m_t: int = 700,\n","    beta_min: float = 0.05,\n","    beta_max: float = 80.0,\n","    seed_landmarks: int = 0,\n","):\n","    \"\"\"\n","    Fit T-only Nyström KRR with Laplace kernel (fixed ell_t), choose beta by LOOCV,\n","    then predict h_hat on t_grid.\n","\n","    Returns:\n","      h_hat_grid (len(t_grid),), beta_star (float)\n","    \"\"\"\n","    T_train = np.asarray(T_train, dtype=float).ravel()\n","    Y_train = np.asarray(Y_train, dtype=float).ravel()\n","    t_grid = np.asarray(t_grid, dtype=float).ravel()\n","\n","    rng = np.random.RandomState(seed_landmarks)\n","    Phi, phi_eval = _build_nystrom_features_laplace(T_train, ell_t=ell_t, m=m_t, rng=rng)\n","\n","    beta_star = _loocv_beta_optimize_svd(Phi, Y_train, beta_min=beta_min, beta_max=beta_max)\n","\n","    # Closed-form ridge in SVD coordinates\n","    U, s, Vt = np.linalg.svd(Phi, full_matrices=False)\n","    Uy = U.T @ Y_train\n","    s2 = s ** 2\n","    coeff = s / (s2 + beta_star)\n","    w_star = Vt.T @ (coeff * Uy)\n","\n","    Phi_grid = phi_eval(t_grid)\n","    h_hat_grid = Phi_grid @ w_star\n","    return np.asarray(h_hat_grid, dtype=float), float(beta_star)\n","\n","\n","def mise_on_grid(h_hat_grid: np.ndarray, h_star_grid: np.ndarray) -> float:\n","    return float(np.mean((np.asarray(h_hat_grid) - np.asarray(h_star_grid)) ** 2))\n","\n","\n","# ----------------------------------------------------------------------\n","# Simulation loop (semi-synthetic regeneration + shuffle per run)\n","# ----------------------------------------------------------------------\n","def run_simulation_t_only(\n","    K: int,\n","    first_seed: int = 1,\n","):\n","    mise_list = []\n","    curves_list = []\n","    beta_list = []\n","    seeds = []\n","\n","    n = len(T)\n","\n","    print(f\"\\n🚀 Running T-only Laplace KRR baseline for K={K} runs ...\")\n","    print(f\"    Fixed ell_t={ELL_T_FIXED}, Nyström m={NYSTROM_M_T}, beta in [{BETA_MIN}, {BETA_MAX}]\")\n","    print(f\"    SciPy minimize_scalar available: {_HAVE_SCIPY}\")\n","\n","    for k in range(K):\n","        seed = first_seed + k\n","        seeds.append(seed)\n","\n","        # Match your legacy reproducibility style: set global np seed per run\n","        np.random.seed(seed)\n","\n","        print(f\"--- Run {k + 1}/{K} (seed={seed}) ---\")\n","\n","        rng_sim = np.random.default_rng(seed)\n","\n","        # 1) Generate semi-synthetic outcome\n","        Y_syn = gen_semi_y(MU_HAT, G_FUNC, rng_sim)\n","\n","        # 2) Permute (X, T, Y) consistently\n","        perm = rng_sim.permutation(n)\n","        Ts = T.iloc[perm].reset_index(drop=True) if hasattr(T, \"iloc\") else np.asarray(T)[perm]\n","        Ys = Y_syn[perm]\n","\n","        # 3) Fit baseline (ignore X)\n","        h_hat_grid, beta_star = estimate_h_grid_t_only_laplace_fixed_ell(\n","            T_train=np.asarray(Ts, dtype=float),\n","            Y_train=np.asarray(Ys, dtype=float),\n","            t_grid=T_GRID,\n","            ell_t=ELL_T_FIXED,\n","            m_t=NYSTROM_M_T,\n","            beta_min=BETA_MIN,\n","            beta_max=BETA_MAX,\n","            seed_landmarks=0,   # keep landmarks deterministic across runs\n","        )\n","\n","        # 4) MISE on grid\n","        mise = mise_on_grid(h_hat_grid, H_STAR_VALS)\n","\n","        mise_list.append(mise)\n","        curves_list.append(h_hat_grid)\n","        beta_list.append(beta_star)\n","\n","        print(f\"  MISE: {mise:.6f} | beta*: {beta_star:.6g}\")\n","\n","    # Aggregate\n","    mise_arr = np.asarray(mise_list, dtype=float)\n","    curves_mat = np.vstack(curves_list)  # (K, grid_size)\n","\n","    mean_curve = curves_mat.mean(axis=0)\n","    std_curve = curves_mat.std(axis=0, ddof=1) if K > 1 else np.zeros_like(mean_curve)\n","    se_curve = std_curve / np.sqrt(K) if K > 1 else np.zeros_like(mean_curve)\n","\n","    beta_arr = np.asarray(beta_list, dtype=float)\n","    beta_mean = float(beta_arr.mean())\n","    beta_std = float(beta_arr.std(ddof=1)) if K > 1 else 0.0\n","    beta_se = float(beta_std / np.sqrt(K)) if K > 1 else 0.0\n","\n","    print(\"\\n\" + \"=\" * 36)\n","    print(f\"Simulation Summary (K={K})\")\n","    print(\"=\" * 36)\n","    print(f\"Mean MISE : {mise_arr.mean():.6f}\")\n","    if K > 1:\n","        print(f\"Std  MISE : {mise_arr.std(ddof=1):.6f}\")\n","        print(f\"SE   MISE : {mise_arr.std(ddof=1) / np.sqrt(K):.6f}\")\n","    print(\"-\" * 36)\n","    print(f\"Mean beta*: {beta_mean:.6g}\")\n","    if K > 1:\n","        print(f\"Std  beta*: {beta_std:.6g}\")\n","        print(f\"SE   beta*: {beta_se:.6g}\")\n","\n","    return {\n","        \"seeds\": seeds,\n","        \"mise_all\": mise_arr,\n","        \"curves_mat\": curves_mat,\n","        \"mean_curve\": mean_curve,\n","        \"se_curve\": se_curve,\n","        \"beta_all\": beta_arr,\n","        \"beta_mean\": beta_mean,\n","        \"beta_se\": beta_se,\n","    }\n","\n","\n","# ----------------------------------------------------------------------\n","# Run + optional save/plot\n","# ----------------------------------------------------------------------\n","results = run_simulation_t_only(K=K_RUNS, first_seed=FIRST_SEED)\n","\n","# Save results to CSV (same layout style as your other scripts)\n","run_tag = f\"direct_semi-real_seeds_{results['seeds'][0]}-{results['seeds'][-1]}\"\n","output_path = RESULTS_DIR / f\"{run_tag}.csv\"\n","\n","df_out = pd.DataFrame({\"t\": T_GRID})\n","for i, seed in enumerate(results[\"seeds\"]):\n","    df_out[f\"h_hat_seed_{seed}\"] = results[\"curves_mat\"][i, :]\n","\n","df_out[\"mean_h_hat\"] = results[\"mean_curve\"]\n","df_out[\"se_h_hat\"] = results[\"se_curve\"]\n","df_out[\"h_star\"] = H_STAR_VALS\n","\n","df_out.to_csv(output_path, index=False)\n","print(f\"\\nSaved curves to: {output_path}\")\n","\n","# Plot mean curve vs truth\n","plt.figure()\n","plt.plot(T_GRID, H_STAR_VALS, label=\"h_star (truth)\")\n","plt.plot(T_GRID, results[\"mean_curve\"], label=\"mean h_hat (T-only Laplace)\")\n","plt.title(f\"T-only Laplace KRR | ell_t={ELL_T_FIXED}, K={K_RUNS}\")\n","plt.legend()\n","plt.show()\n"]}]}