{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "1878cadc",
   "metadata": {},
   "source": [
    "# Setup\n",
    "\n",
    "Please ensure all the relevant modules are installed before running the below! This can be simply achieved via the command below in your virtual environment:\n",
    "```\n",
    "pip install -r requirements.txt\n",
    "```\n",
    "This can be run locally on a personal laptop."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "69475e79",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d709bb79",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.special import logsumexp\n",
    "from scipy.stats import gaussian_kde\n",
    "from sklearn.model_selection import KFold, train_test_split\n",
    "from filterpy.monte_carlo import systematic_resample\n",
    "import math\n",
    "\n",
    "import sys\n",
    "import os\n",
    "import time\n",
    "import json\n",
    "import urllib.request\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as mticker\n",
    "from tueplots import bundles\n",
    "\n",
    "from typing import Dict, Any, List, Optional, Union, Tuple\n",
    "from numpy.typing import NDArray\n",
    "from dataclasses import dataclass, field, asdict\n",
    "from types import SimpleNamespace"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d838b528",
   "metadata": {},
   "source": [
    "# Experiment Config\n",
    "\n",
    "The following controls hyperparameters related to the experimental trial we run.\n",
    "\n",
    "*Ideally, we would refactor this logic such that the config is instantiated later and passed to functions at runtime!*"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1a68d821",
   "metadata": {},
   "outputs": [],
   "source": [
    "# For reproducibility\n",
    "SEED = 123\n",
    "rng_global = np.random.default_rng(SEED)\n",
    "\n",
    "@dataclass(frozen=True)\n",
    "class Cfg:\n",
    "    prior_var       : float = 5.0\n",
    "    particle_count  : int   = 10  # N\n",
    "    kfold_splits    : int   = 3\n",
    "    test_fraction   : float = 0.20\n",
    "    early_patience  : int   = 10\n",
    "    eval_gap        : int   = 10\n",
    "    max_pgd_iters   : int   = 500\n",
    "    max_mmle_steps  : int   = 500\n",
    "    ess_fraction    : float = 1.0 / 1.05  # C\n",
    "    eta_theta_grid  : NDArray = field(default_factory=lambda: np.array([0.05, 0.1, 0.15]))\n",
    "    nll_tol         : float = 1e-5\n",
    "\n",
    "cfg = Cfg()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b7d7de45",
   "metadata": {},
   "source": [
    "# Utility Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c34618fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "### Data Loading ###\n",
    "\n",
    "def load_breast_cancer() -> Tuple[NDArray, NDArray]:\n",
    "    \"\"\"\n",
    "    As in: https://colab.research.google.com/github/juankuntz/ParEM/blob/main/jax/bayesian_logistic_regression.ipynb\n",
    "    \"\"\"\n",
    "    global D_global\n",
    "\n",
    "    url = (\n",
    "        \"https://archive.ics.uci.edu/ml/machine-learning-databases/\"\n",
    "        \"breast-cancer-wisconsin/breast-cancer-wisconsin.data\"\n",
    "    )\n",
    "    \n",
    "    script_dir = os.path.dirname(os.path.abspath(__file__) if '__file__' in globals() else os.getcwd())\n",
    "    local = os.path.join(script_dir, \"breast-cancer-wisconsin.data\")\n",
    "\n",
    "    if not os.path.exists(local):\n",
    "        print(f\"Downloading {local} from {url}...\")\n",
    "        try: \n",
    "            urllib.request.urlretrieve(url, local)\n",
    "            print(\"Download complete!\")\n",
    "        except Exception as e: \n",
    "            print(f\"Error downloading dataset: {e}\")\n",
    "            sys.exit(1)\n",
    "\n",
    "    raw = np.loadtxt(local, dtype=str, delimiter=\",\")\n",
    "    raw = raw[~(raw == \"?\").any(axis=1)].astype(float)\n",
    "    X = raw[:, 1:10]\n",
    "    X = (X - X.mean(0)) / X.std(0)\n",
    "    y = ((raw[:, 10] - 2) / 2).astype(float)\n",
    "    D_global = X.shape[1]\n",
    "\n",
    "    return X, y\n",
    "\n",
    "\n",
    "SIG2 = cfg.prior_var\n",
    "INV_SIG2 = 1.0 / SIG2\n",
    "HALF_INV_SIG2 = 0.5 * INV_SIG2\n",
    "\n",
    "\n",
    "def sigmoid(z: NDArray) -> NDArray:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    out = np.empty_like(z, dtype=float)\n",
    "    z_float = z.astype(float)\n",
    "    pos = z_float >= 0\n",
    "    out[pos]  = 1.0 / (1.0 + np.exp(-z_float[pos]))\n",
    "    ez_neg = np.exp(z_float[~pos])\n",
    "    out[~pos] = ez_neg / (1.0 + ez_neg)\n",
    "\n",
    "    return out\n",
    "\n",
    "\n",
    "def lipschitz_logistic(X: NDArray, prior_var: float = SIG2, power_iter: int = 20, tol: float = 1e-10) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X.shape[0] == 0 or X.shape[1] == 0:\n",
    "        return 1.0 / prior_var\n",
    "    \n",
    "    v_rng = np.random.default_rng(SEED + 100)\n",
    "    v = v_rng.standard_normal(X.shape[1])\n",
    "    norm_v = np.linalg.norm(v)\n",
    "\n",
    "    if norm_v < tol: \n",
    "        v = np.ones(X.shape[1]) / math.sqrt(X.shape[1] if X.shape[1] > 0 else 1.0)\n",
    "    else: \n",
    "        v /= norm_v\n",
    "\n",
    "    nrm = 0.0\n",
    "    for _ in range(power_iter):\n",
    "        Hv = 0.25 * X.T @ (X @ v) + v / prior_var\n",
    "        nrm = np.linalg.norm(Hv)\n",
    "\n",
    "        if nrm < tol:\n",
    "            return 1.0 / prior_var\n",
    "        \n",
    "        v = Hv / nrm\n",
    "\n",
    "    return nrm if nrm > tol else 1.0 / prior_var\n",
    "\n",
    "\n",
    "def safe_constant_step(X: NDArray, prior_var: float = SIG2, safety: float = 0.9) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    L = lipschitz_logistic(X, prior_var, power_iter=40)\n",
    "\n",
    "    return (safety / L) if L > 1e-6 else 1.0\n",
    "\n",
    "\n",
    "def energy(theta: float, parts: NDArray, X: NDArray, y: NDArray) -> NDArray:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X.shape[0] == 0: \n",
    "        return HALF_INV_SIG2 * np.square(parts - theta).sum(axis=0)\n",
    "    \n",
    "    y_col = y.reshape(-1, 1)\n",
    "\n",
    "    logits = X @ parts\n",
    "\n",
    "    stable_log_plus_exp = np.maximum(0, logits) + np.log1p(np.exp(-np.abs(logits)))\n",
    "\n",
    "    nll = stable_log_plus_exp - y_col * logits\n",
    "\n",
    "    prior = HALF_INV_SIG2 * np.square(parts - theta).sum(axis=0)\n",
    "    \n",
    "    return nll.sum(axis=0) + prior\n",
    "\n",
    "\n",
    "def grad_parts(theta: float, parts: NDArray, X: NDArray, y: NDArray) -> NDArray:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X.shape[0] == 0: \n",
    "        return INV_SIG2 * (parts - theta)\n",
    "    \n",
    "    y_col = y.reshape(-1,1)\n",
    "\n",
    "    logits = X @ parts\n",
    "\n",
    "    grad_nll_w = X.T @ (sigmoid(logits) - y_col)\n",
    "\n",
    "    grad_prior_energy_w = INV_SIG2 * (parts - theta)\n",
    "\n",
    "    return grad_nll_w + grad_prior_energy_w\n",
    "\n",
    "\n",
    "def mean_grad_theta(theta: float, parts: NDArray) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if parts.shape[1] == 0: \n",
    "        return 0.0\n",
    "    \n",
    "    return (-INV_SIG2 * (parts - theta).sum(axis=0)).mean()\n",
    "\n",
    "\n",
    "def grad_theta_per_particle(theta: float, parts: NDArray) -> NDArray:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    return INV_SIG2 * (parts - theta).sum(axis=0)\n",
    "\n",
    "\n",
    "def predictive_nll(parts: NDArray, X: NDArray, y: NDArray, eps: float = 1e-12) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X.shape[0] == 0 or parts.shape[1] == 0:\n",
    "        return np.log(2.0)\n",
    "    \n",
    "    probs = sigmoid(X @ parts).mean(axis=1)\n",
    "    probs = np.clip(probs, eps, 1.0 - eps)\n",
    "\n",
    "    nll_val = -np.mean(y * np.log(probs) + (1 - y) * np.log(1 - probs))\n",
    "\n",
    "    return nll_val if np.isfinite(nll_val) else np.log(2.0)\n",
    "\n",
    "\n",
    "def weighted_nll(parts: NDArray, logw: NDArray, X: NDArray, y: NDArray, eps: float = 1e-12) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if X.shape[0] == 0 or parts.shape[1] == 0: \n",
    "        return np.log(2.0)\n",
    "    \n",
    "    if np.all(np.isneginf(logw)) or len(logw) == 0: \n",
    "        return predictive_nll(parts, X, y, eps)\n",
    "    \n",
    "    logw_safe = np.nan_to_num(logw, nan=-np.inf, posinf=np.inf, neginf=-np.inf)\n",
    "\n",
    "    if np.any(np.isposinf(logw_safe)):\n",
    "        posinf_idx = np.where(np.isposinf(logw_safe))[0]\n",
    "        return predictive_nll(parts[:, posinf_idx] if len(posinf_idx) > 0 and parts.shape[1] > np.max(posinf_idx) else parts, X, y, eps)\n",
    "    \n",
    "    try:\n",
    "        lse = logsumexp(logw_safe)\n",
    "\n",
    "        if not np.isfinite(lse): \n",
    "            return predictive_nll(parts, X, y, eps)\n",
    "        \n",
    "        w_norm = np.exp(logw_safe - lse)\n",
    "\n",
    "    except FloatingPointError:\n",
    "        return predictive_nll(parts, X, y, eps)\n",
    "    \n",
    "    probs = (sigmoid(X @ parts) * w_norm.reshape(1, -1)).sum(axis=1)\n",
    "    probs = np.clip(probs, eps, 1.0 - eps)\n",
    "    nll_val = -np.mean(y * np.log(probs) + (1 - y) * np.log(1 - probs))\n",
    "\n",
    "    return nll_val if np.isfinite(nll_val) else np.log(2.0)\n",
    "\n",
    "\n",
    "def ess_from_logw(logw: NDArray) -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if len(logw) == 0: \n",
    "        return 0.0\n",
    "    \n",
    "    logw_safe = np.nan_to_num(logw, nan=-np.inf, posinf=np.inf, neginf=-np.inf)\n",
    "\n",
    "    if np.all(np.isneginf(logw_safe)): \n",
    "        return 0.0\n",
    "    \n",
    "    if np.any(np.isposinf(logw_safe)): \n",
    "        return 1.0\n",
    "    \n",
    "    lse = logsumexp(logw_safe)\n",
    "\n",
    "    if not np.isfinite(lse):\n",
    "        return 0.0\n",
    "    \n",
    "    w = np.exp(logw_safe - lse)\n",
    "    sum_sq_w = (w ** 2).sum()\n",
    "    \n",
    "    return 1.0 / sum_sq_w if sum_sq_w > 1e-12 else float(len(logw))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63bfe5f6",
   "metadata": {},
   "source": [
    "# JALA-EM\n",
    "\n",
    "Implementation of the JALA-EM algorithm, as described in \"Learning Latent Variable Models via Jarzynski-adjusted Langevin Algorithm\" (see: https://arxiv.org/pdf/2505.18427). Specifically see Appendix C.2 of the aforementioned paper."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0fee5f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def alpha_calculator(\n",
    "    x_l: NDArray,\n",
    "    x_r: NDArray,\n",
    "    theta_for_U: float,\n",
    "    grad_U_at_xl: NDArray,\n",
    "    X_data: NDArray,\n",
    "    y_data: NDArray,\n",
    "    h_step: float,\n",
    ") -> float:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    U_xl = energy(theta_for_U, x_l, X_data, y_data)[0]\n",
    "    term2 = 0.5 * np.sum((x_r - x_l) * grad_U_at_xl)\n",
    "    term3 = (h_step / 4.0) * np.sum(np.square(grad_U_at_xl))\n",
    "\n",
    "    return U_xl + term2 + term3\n",
    "\n",
    "def jala_em_step(\n",
    "    X_data: NDArray,\n",
    "    y_data: NDArray,\n",
    "    *,\n",
    "    parts_k: NDArray,\n",
    "    theta_k: float,\n",
    "    log_A_k: NDArray,\n",
    "    h_part: float,\n",
    "    eta_theta: float,\n",
    "    ess_threshold_frac: float,\n",
    "    rng: np.random.Generator,\n",
    ") -> Tuple[float, NDArray, NDArray, float, float, bool]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    N_particles = parts_k.shape[1]\n",
    "    D_particles = parts_k.shape[0]\n",
    "    did_resample_flag = False\n",
    "\n",
    "    if N_particles == 0:\n",
    "        return theta_k, parts_k, log_A_k, 0.0, 0.0, did_resample_flag\n",
    "    \n",
    "    safe_log_A_k = np.nan_to_num(log_A_k, nan=-np.inf, neginf=-np.inf)\n",
    "\n",
    "    if np.all(np.isneginf(safe_log_A_k)): \n",
    "        w_norm_k = np.ones(N_particles) / N_particles if N_particles > 0 else np.array([])\n",
    "    else:\n",
    "        lse_A_k = logsumexp(safe_log_A_k)\n",
    "        w_norm_k = np.exp(safe_log_A_k - lse_A_k if np.isfinite(lse_A_k) else safe_log_A_k)\n",
    "\n",
    "    g_k_theta_component = np.sum(w_norm_k * grad_theta_per_particle(theta_k, parts_k))\n",
    "\n",
    "    theta_k_plus_1 = theta_k + eta_theta * g_k_theta_component\n",
    "    parts_k_plus_1 = np.empty_like(parts_k)\n",
    "    log_A_k_plus_1_accumulated = np.empty_like(log_A_k)\n",
    "\n",
    "    for i in range(N_particles):\n",
    "        xi_k_curr = parts_k[:, i:i+1]\n",
    "        grad_U_k_at_xi_k = grad_parts(theta_k, xi_k_curr, X_data, y_data)\n",
    "        xi_k_plus_1_new = xi_k_curr - (h_part * grad_U_k_at_xi_k) + (math.sqrt(2 * h_part) * rng.standard_normal((D_particles, 1)))\n",
    "\n",
    "        parts_k_plus_1[:, i:i+1] = xi_k_plus_1_new\n",
    "\n",
    "        alpha_curr_U_k = alpha_calculator(xi_k_curr, xi_k_plus_1_new, theta_k, grad_U_k_at_xi_k, X_data, y_data, h_part)\n",
    "\n",
    "        grad_U_kp1_at_xi_kp1 = grad_parts(theta_k_plus_1, xi_k_plus_1_new, X_data, y_data)\n",
    "\n",
    "        alpha_next_U_kp1 = alpha_calculator(xi_k_plus_1_new, xi_k_curr, theta_k_plus_1, grad_U_kp1_at_xi_kp1, X_data, y_data, h_part)\n",
    "        log_A_k_plus_1_accumulated[i] = log_A_k[i] - alpha_next_U_kp1 + alpha_curr_U_k\n",
    "\n",
    "    log_A_k_plus_1_accumulated = np.nan_to_num(\n",
    "        log_A_k_plus_1_accumulated, \n",
    "        nan=-np.inf,\n",
    "        posinf=np.log(np.finfo(float).max / (N_particles +1e-9)) if N_particles > 0 else 0.0,  # Set to log of large number!\n",
    "        neginf=-np.inf\n",
    "    )\n",
    "\n",
    "    ess_before_resampling = ess_from_logw(log_A_k_plus_1_accumulated)\n",
    "\n",
    "    final_log_A_for_next_step = np.copy(log_A_k_plus_1_accumulated)\n",
    "\n",
    "    if ess_before_resampling < ess_threshold_frac * N_particles and N_particles > 1:\n",
    "        safe_log_A_accumulated = np.nan_to_num(log_A_k_plus_1_accumulated, nan=-np.inf, neginf=-np.inf)\n",
    "\n",
    "        if not np.all(np.isneginf(safe_log_A_accumulated)):\n",
    "            lse_A_accumulated = logsumexp(safe_log_A_accumulated)\n",
    "\n",
    "            if np.isfinite(lse_A_accumulated):\n",
    "                resampling_probs = np.exp(safe_log_A_accumulated - lse_A_accumulated)\n",
    "\n",
    "                if np.all(np.isfinite(resampling_probs)) and np.all(resampling_probs >= 0):\n",
    "                    sum_probs = np.sum(resampling_probs)\n",
    "\n",
    "                    if np.isclose(sum_probs, 1.0, atol=1e-5):\n",
    "                        try:\n",
    "                            idx = systematic_resample(resampling_probs)\n",
    "                            parts_k_plus_1 = parts_k_plus_1[:, idx]\n",
    "                            final_log_A_for_next_step.fill(0.0) # Reset log weights after resampling\n",
    "                            did_resample_flag = True\n",
    "\n",
    "                        except Exception:\n",
    "                            pass # Gracefully handle potential resampling issues (if any)\n",
    "\n",
    "    ess_after_resampling = ess_from_logw(final_log_A_for_next_step)\n",
    "\n",
    "    return theta_k_plus_1, parts_k_plus_1, final_log_A_for_next_step, ess_before_resampling, ess_after_resampling, did_resample_flag\n",
    "\n",
    "def jala_em_accurate_for_trajectory_timed(\n",
    "    X: NDArray, \n",
    "    y: NDArray, \n",
    "    *, \n",
    "    h_part: float, \n",
    "    eta_theta: float, \n",
    "    n_particles: int,\n",
    "    max_duration_seconds: float, \n",
    "    target_iter_mark: int,\n",
    "    ess_threshold_frac: float, \n",
    "    rng: np.random.Generator,\n",
    ") -> Tuple[NDArray, NDArray, int, Optional[float], Optional[float], NDArray, NDArray, NDArray, NDArray, List[bool]]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    theta = 0.0\n",
    "    parts = rng.standard_normal((D_global, n_particles)) * math.sqrt(SIG2)\n",
    "    log_A = np.zeros(n_particles) # Initial log weights A_0\n",
    "\n",
    "    # Calculate ESS for the initial state (i.e. A_0 = np.zeros(N))\n",
    "    initial_ess_val = ess_from_logw(log_A) # Should begin at `n_particles`\n",
    "\n",
    "    theta_hist_list = [theta] # \\theta at k=0\n",
    "    time_hist_list = [0.0]    # Time elapsed at k=0\n",
    "\n",
    "    # Initialise lists to track quantities\n",
    "    ess_before_resampling_hist = [initial_ess_val]\n",
    "    ess_after_resampling_hist = [initial_ess_val]\n",
    "    resampling_occurred_hist = [False] # Note no resampling has occurred for the initial state\n",
    "\n",
    "    time_at_target_iter = None\n",
    "    theta_at_target_iter = None\n",
    "    start_time = time.perf_counter()\n",
    "    k_steps_taken = 0\n",
    "\n",
    "    # The below loop calculates values for k=1, 2, ... in terms of updates, as the 0-th state is already recorded\n",
    "    while True:\n",
    "        elapsed_time = time.perf_counter() - start_time\n",
    "\n",
    "        if k_steps_taken > 0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0:\n",
    "            break\n",
    "\n",
    "        if k_steps_taken == 0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0: # Note: Allows one run if time is very short\n",
    "            pass\n",
    "\n",
    "        elif k_steps_taken == 0 and max_duration_seconds <= 0:\n",
    "            break\n",
    "\n",
    "\n",
    "        # current_theta is theta_k (from previous iteration or initial) and log_A is A_k (from previous iteration or initial)\n",
    "        current_theta_for_step = theta_hist_list[-1] # i.e theta_k\n",
    "        current_log_A_for_step = np.copy(log_A)      # i.e. A_k\n",
    "\n",
    "        # One step of JALA-EM\n",
    "        theta_kp1, parts_kp1, next_log_A, current_ess_before, current_ess_after, did_resample = jala_em_step(\n",
    "            X, \n",
    "            y, \n",
    "            parts_k=parts, \n",
    "            theta_k=current_theta_for_step, \n",
    "            log_A_k=current_log_A_for_step,\n",
    "            h_part=h_part, \n",
    "            eta_theta=eta_theta, \n",
    "            ess_threshold_frac=ess_threshold_frac, \n",
    "            rng=rng,\n",
    "        )\n",
    "\n",
    "        # Update states\n",
    "        theta = theta_kp1\n",
    "        parts = parts_kp1\n",
    "        log_A = next_log_A\n",
    "\n",
    "        k_steps_taken += 1 # Increment step count\n",
    "\n",
    "        # Store results for iteration k\n",
    "        theta_hist_list.append(theta)\n",
    "        current_elapsed_time = time.perf_counter() - start_time\n",
    "        time_hist_list.append(current_elapsed_time)\n",
    "        ess_before_resampling_hist.append(current_ess_before)\n",
    "        ess_after_resampling_hist.append(current_ess_after)\n",
    "        resampling_occurred_hist.append(did_resample)\n",
    "\n",
    "        if k_steps_taken == target_iter_mark and time_at_target_iter is None:\n",
    "            time_at_target_iter = current_elapsed_time\n",
    "            theta_at_target_iter = theta\n",
    "        \n",
    "        # Check break condition again\n",
    "        if k_steps_taken == 1 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0:\n",
    "            if not (k_steps_taken > 0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0):\n",
    "                 break\n",
    "\n",
    "\n",
    "    return (\n",
    "        np.array(theta_hist_list), \n",
    "        np.array(time_hist_list), \n",
    "        k_steps_taken,\n",
    "        time_at_target_iter, \n",
    "        theta_at_target_iter,\n",
    "        np.array(ess_before_resampling_hist), \n",
    "        np.array(ess_after_resampling_hist),\n",
    "        parts, \n",
    "        log_A, \n",
    "        resampling_occurred_hist\n",
    "    )\n",
    "\n",
    "\n",
    "def tune_jala_em(\n",
    "    X_data_tune: NDArray, \n",
    "    y_data_tune: NDArray, \n",
    "    h_grid_tune: NDArray, \n",
    "    eta_grid_tune: NDArray, \n",
    "    *,\n",
    "    n_particles_tune: int, \n",
    "    rng_tune: np.random.Generator, \n",
    "    kfold_tune: KFold,\n",
    ") -> Tuple[Tuple[float, float], int, Dict[Tuple[float, float], float]]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    cv_score, cv_stop = {}, {}\n",
    "    print(f\"  Tuning JALA-EM over {len(h_grid_tune)} h_part and {len(eta_grid_tune)} eta_theta values...\")\n",
    "\n",
    "    for h_val in h_grid_tune: # `h` for JALA-EM\n",
    "        for eta_val in eta_grid_tune: # OPT step-size for JALA-EM\n",
    "            fold_best_nll, fold_best_iter = [], []\n",
    "            for tr_idx, va_idx in kfold_tune.split(X_data_tune, y_data_tune):\n",
    "                X_tr, y_tr = X_data_tune[tr_idx], y_data_tune[tr_idx]\n",
    "                X_va, y_va = X_data_tune[va_idx], y_data_tune[va_idx]\n",
    "\n",
    "                if X_tr.shape[0] == 0 or X_va.shape[0] == 0: \n",
    "                    continue\n",
    "\n",
    "                theta_tune = 0.0\n",
    "                parts_tune = rng_tune.standard_normal((D_global, n_particles_tune)) * math.sqrt(SIG2)\n",
    "                log_A_tune = np.zeros(n_particles_tune)\n",
    "\n",
    "                best_nll_fold, wait, best_iter_fold = math.inf, 0, 0\n",
    "                for k_tune in range(cfg.max_mmle_steps): # Max EM iterations for tuning\n",
    "                    if k_tune % cfg.eval_gap == 0 or k_tune == cfg.max_mmle_steps - 1:\n",
    "                        current_nll = weighted_nll(parts_tune, log_A_tune, X_va, y_va)\n",
    "\n",
    "                        if current_nll < best_nll_fold - cfg.nll_tol:\n",
    "                            best_nll_fold, best_iter_fold, wait = current_nll, k_tune, 0\n",
    "                        else:\n",
    "                            wait += 1\n",
    "\n",
    "                        if wait >= cfg.early_patience and k_tune > 0:\n",
    "                            break\n",
    "\n",
    "                    theta_tune, parts_tune, log_A_tune, _, _, _ = jala_em_step(\n",
    "                        X_tr,\n",
    "                        y_tr, \n",
    "                        parts_k=parts_tune, \n",
    "                        theta_k=theta_tune,\n",
    "                        log_A_k=log_A_tune,\n",
    "                        h_part=h_val, eta_theta=eta_val,\n",
    "                        ess_threshold_frac=cfg.ess_fraction,\n",
    "                        rng=rng_tune\n",
    "                    )\n",
    "\n",
    "                fold_best_nll.append(best_nll_fold)\n",
    "                fold_best_iter.append(best_iter_fold)\n",
    "\n",
    "            if fold_best_nll:\n",
    "                cv_score[(h_val, eta_val)] = np.mean(fold_best_nll)\n",
    "                cv_stop[(h_val, eta_val)] = int(np.mean(fold_best_iter))\n",
    "\n",
    "    h_eta_star = min(cv_score, key=cv_score.get) if cv_score else ((h_grid_tune[0] if len(h_grid_tune) > 0 else 0.001), \\\n",
    "                  (eta_grid_tune[0] if len(eta_grid_tune) > 0 else 0.01))\n",
    "    \n",
    "    iter_star = cv_stop.get(h_eta_star, cfg.max_mmle_steps)\n",
    "    \n",
    "    return h_eta_star, iter_star, cv_score"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d1da1f68",
   "metadata": {},
   "source": [
    "# PGD\n",
    "\n",
    "Implementation of the PGD algorithm as described in \"Particle algorithms for maximum likelihood training of latent variable models\" (see: https://arxiv.org/pdf/2204.12965). Also see: https://colab.research.google.com/github/juankuntz/ParEM/blob/main/jax/bayesian_logistic_regression.ipynb for inspiration."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8bedb987",
   "metadata": {},
   "outputs": [],
   "source": [
    "def pgd_const_for_trajectory_timed(\n",
    "    X: NDArray,\n",
    "    y: NDArray,\n",
    "    *,\n",
    "    step: float,\n",
    "    n_particles: int,\n",
    "    max_duration_seconds: float,\n",
    "    target_iter_mark: int,\n",
    "    rng: np.random.Generator,\n",
    ") -> Tuple[NDArray, NDArray, int, Optional[float], Optional[float], NDArray]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    \n",
    "    theta = 0.0\n",
    "    parts = rng.standard_normal((D_global, n_particles)) * math.sqrt(SIG2)\n",
    "\n",
    "    theta_hist_list = [theta]\n",
    "    time_hist_list = [0.0]\n",
    "    \n",
    "    time_at_target_iter = None\n",
    "    theta_at_target_iter = None\n",
    "\n",
    "    start_time = time.perf_counter()\n",
    "    k = 0\n",
    "\n",
    "    while True:\n",
    "        elapsed_time = time.perf_counter() - start_time\n",
    "\n",
    "        if k > 0 and elapsed_time >= max_duration_seconds:\n",
    "            break\n",
    "\n",
    "        if k == 0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0: \n",
    "            pass\n",
    "\n",
    "        elif k == 0 and max_duration_seconds <= 0: \n",
    "            break\n",
    "\n",
    "        current_grad_w = grad_parts(theta, parts, X, y)\n",
    "        \n",
    "        parts -= step * current_grad_w\n",
    "        parts += math.sqrt(2 * step) * rng.standard_normal(parts.shape)\n",
    "        theta -= step * mean_grad_theta(theta, parts)\n",
    "\n",
    "        k += 1\n",
    "        theta_hist_list.append(theta)\n",
    "\n",
    "        current_elapsed_time = time.perf_counter() - start_time\n",
    "        time_hist_list.append(current_elapsed_time)\n",
    "\n",
    "        if k == target_iter_mark and time_at_target_iter is None:\n",
    "            time_at_target_iter = current_elapsed_time\n",
    "            theta_at_target_iter = theta\n",
    "\n",
    "        if k==0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0: \n",
    "            break\n",
    "\n",
    "    return np.array(theta_hist_list), np.array(time_hist_list), k, time_at_target_iter, theta_at_target_iter, parts\n",
    "\n",
    "def tune_pgd(\n",
    "    X_data_tune: NDArray,\n",
    "    y_data_tune: NDArray,\n",
    "    h_grid_tune: NDArray,\n",
    "    *,\n",
    "    n_particles_tune: int,\n",
    "    rng_tune: np.random.Generator,\n",
    "    kfold_tune: KFold,\n",
    ") -> Tuple[float, int, Dict[float, float]]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    cv_score, cv_stop = {}, {}\n",
    "\n",
    "    print(f\"Tuning PGD over {len(h_grid_tune)} h values...\")\n",
    "    for h_val in h_grid_tune:\n",
    "        fold_best_nll, fold_best_iter = [], []\n",
    "        for tr_idx, va_idx in kfold_tune.split(X_data_tune, y_data_tune):\n",
    "            X_tr, y_tr = X_data_tune[tr_idx], y_data_tune[tr_idx]\n",
    "            X_va, y_va = X_data_tune[va_idx], y_data_tune[va_idx]\n",
    "\n",
    "            if X_tr.shape[0] == 0 or X_va.shape[0] == 0:\n",
    "                continue\n",
    "\n",
    "            theta_tune = 0.0\n",
    "            parts_tune = rng_tune.standard_normal((D_global, n_particles_tune)) * math.sqrt(SIG2)\n",
    "            best_nll_fold, wait, best_iter_fold = math.inf, 0, 0\n",
    "\n",
    "            for k_tune in range(cfg.max_pgd_iters):\n",
    "                if k_tune % cfg.eval_gap == 0 or k_tune == cfg.max_pgd_iters -1:\n",
    "                    current_nll = predictive_nll(parts_tune, X_va, y_va)\n",
    "\n",
    "                    if current_nll < best_nll_fold - cfg.nll_tol:\n",
    "                        best_nll_fold, best_iter_fold, wait = current_nll, k_tune, 0\n",
    "                    else:\n",
    "                        wait += 1\n",
    "\n",
    "                    if wait >= cfg.early_patience and k_tune > 0:\n",
    "                        break\n",
    "\n",
    "                current_grad_w_tune = grad_parts(theta_tune, parts_tune, X_tr, y_tr)\n",
    "\n",
    "                parts_tune -= h_val * current_grad_w_tune\n",
    "                parts_tune += math.sqrt(2 * h_val) * rng_tune.standard_normal(parts_tune.shape)\n",
    "                theta_tune -= h_val * mean_grad_theta(theta_tune, parts_tune)\n",
    "\n",
    "            fold_best_nll.append(best_nll_fold)\n",
    "            fold_best_iter.append(best_iter_fold)\n",
    "\n",
    "        if fold_best_nll:\n",
    "            cv_score[h_val] = np.mean(fold_best_nll)\n",
    "            cv_stop[h_val] = int(np.mean(fold_best_iter))\n",
    "\n",
    "    h_star_val = min(cv_score, key=cv_score.get) if cv_score else (h_grid_tune[0] if len(h_grid_tune) > 0 else 0.001)\n",
    "    iter_star = cv_stop.get(h_star_val, cfg.max_pgd_iters)\n",
    "\n",
    "    return h_star_val, iter_star, cv_score"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "66a25fd2",
   "metadata": {},
   "source": [
    "# SOUL\n",
    "\n",
    "Implementation of the SOUL algorithm as described in \"Particle algorithms for maximum likelihood training of latent variable models\" (see: https://arxiv.org/pdf/2204.12965). Also see: https://colab.research.google.com/github/juankuntz/ParEM/blob/main/jax/bayesian_logistic_regression.ipynb#scrollTo=LtqjvuN98ZmU for inspiration."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5deda600",
   "metadata": {},
   "outputs": [],
   "source": [
    "def soul_const_for_trajectory_timed(\n",
    "    X: NDArray,\n",
    "    y: NDArray,\n",
    "    *,\n",
    "    step_x: float,\n",
    "    step_theta: float,\n",
    "    m_inner: int,\n",
    "    max_duration_seconds: float,\n",
    "    target_iter_mark: int,\n",
    "    n_particles: int,\n",
    "    rng: np.random.Generator,\n",
    ") -> Tuple[NDArray, NDArray, int, Optional[float], Optional[float], NDArray]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    theta = 0.0\n",
    "    parts = rng.standard_normal((D_global, n_particles)) * math.sqrt(SIG2)\n",
    "    \n",
    "    theta_hist_list = [theta]\n",
    "    time_hist_list = [0.0]\n",
    "\n",
    "    time_at_target_iter = None\n",
    "    theta_at_target_iter = None\n",
    "\n",
    "    start_time = time.perf_counter()\n",
    "    t = 0\n",
    "\n",
    "    while True:\n",
    "        elapsed_time = time.perf_counter() - start_time\n",
    "\n",
    "        if t > 0 and elapsed_time >= max_duration_seconds:\n",
    "            break\n",
    "        if t == 0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0:\n",
    "            pass\n",
    "        elif t == 0 and max_duration_seconds <=0:\n",
    "            break\n",
    "        \n",
    "        # Start Inner Loop!\n",
    "        for _ in range(m_inner):\n",
    "            current_grad_w = grad_parts(theta, parts, X, y)\n",
    "\n",
    "            parts -= step_x * current_grad_w\n",
    "            parts += math.sqrt(2.0 * step_x) * rng.standard_normal(parts.shape)\n",
    "        # End Inner Loop!\n",
    "\n",
    "        theta -= step_theta * mean_grad_theta(theta, parts)\n",
    "        t += 1\n",
    "\n",
    "        theta_hist_list.append(theta)\n",
    "\n",
    "        current_elapsed_time = time.perf_counter() - start_time\n",
    "        time_hist_list.append(current_elapsed_time)\n",
    "\n",
    "        if t == target_iter_mark and time_at_target_iter is None:\n",
    "            time_at_target_iter = current_elapsed_time\n",
    "            theta_at_target_iter = theta\n",
    "\n",
    "        if t==0 and elapsed_time >= max_duration_seconds and max_duration_seconds > 0:\n",
    "            break\n",
    "\n",
    "    return np.array(theta_hist_list), np.array(time_hist_list), t, time_at_target_iter, theta_at_target_iter, parts\n",
    "\n",
    "\n",
    "def tune_soul(\n",
    "    X_data_tune: NDArray,\n",
    "    y_data_tune: NDArray,\n",
    "    gamma_grid_tune: NDArray,\n",
    "    eta_grid_tune: NDArray, *,\n",
    "    m_inner_tune: int,\n",
    "    n_particles_tune: int,\n",
    "    rng_tune: np.random.Generator,\n",
    "    kfold_tune: KFold,\n",
    ") -> Tuple[Tuple[float, float], int, Dict[Tuple[float,float], float]]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    cv_score, cv_stop = {}, {}\n",
    "    \n",
    "    print(f\"Tuning SOUL over {len(gamma_grid_tune)} gamma and {len(eta_grid_tune)} eta values...\")\n",
    "    for gamma_val in gamma_grid_tune:\n",
    "        for eta_val in eta_grid_tune:\n",
    "            fold_best_nll, fold_best_iter = [], []\n",
    "            for tr_idx, va_idx in kfold_tune.split(X_data_tune, y_data_tune):\n",
    "                X_tr, y_tr = X_data_tune[tr_idx], y_data_tune[tr_idx]\n",
    "                X_va, y_va = X_data_tune[va_idx], y_data_tune[va_idx]\n",
    "\n",
    "                if X_tr.shape[0] == 0 or X_va.shape[0] == 0:\n",
    "                    continue\n",
    "\n",
    "                theta_tune = 0.0\n",
    "                parts_tune = rng_tune.standard_normal((D_global, n_particles_tune)) * math.sqrt(SIG2)\n",
    "\n",
    "                best_nll_fold, wait, best_iter_fold = math.inf, 0, 0\n",
    "                \n",
    "                for t_tune in range(cfg.max_mmle_steps):\n",
    "\n",
    "                    for _ in range(m_inner_tune):\n",
    "                        current_grad_w_tune = grad_parts(theta_tune, parts_tune, X_tr, y_tr)\n",
    "                        parts_tune -= gamma_val * current_grad_w_tune\n",
    "                        parts_tune += math.sqrt(2.0 * gamma_val) * rng_tune.standard_normal(parts_tune.shape)\n",
    "\n",
    "                    theta_tune -= eta_val * mean_grad_theta(theta_tune, parts_tune)\n",
    "\n",
    "                    if t_tune % cfg.eval_gap == 0 or t_tune == cfg.max_mmle_steps -1:\n",
    "                        current_nll = predictive_nll(parts_tune, X_va, y_va)\n",
    "\n",
    "                        if current_nll < best_nll_fold - cfg.nll_tol:\n",
    "                            best_nll_fold, best_iter_fold, wait = current_nll, t_tune, 0\n",
    "\n",
    "                        else:\n",
    "                            wait += 1\n",
    "\n",
    "                        if wait >= cfg.early_patience and t_tune > 0:\n",
    "                            break\n",
    "\n",
    "                fold_best_nll.append(best_nll_fold)\n",
    "                fold_best_iter.append(best_iter_fold)\n",
    "\n",
    "            if fold_best_nll:\n",
    "                cv_score[(gamma_val, eta_val)] = np.mean(fold_best_nll)\n",
    "                cv_stop [(gamma_val, eta_val)] = int(np.mean(fold_best_iter))\n",
    "\n",
    "    gamma_eta_star = min(cv_score, key=cv_score.get) if cv_score else ((gamma_grid_tune[0] if len(gamma_grid_tune)>0 else 0.001), (eta_grid_tune[0] if len(eta_grid_tune)>0 else 0.01))\n",
    "    iter_star = cv_stop.get(gamma_eta_star, cfg.max_mmle_steps)\n",
    "    \n",
    "    return gamma_eta_star, iter_star, cv_score\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c6162eed",
   "metadata": {},
   "source": [
    "# Experimental Trial (Optional to Run)\n",
    "Feel free to skip this and simply load and plot data later!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "176dbd18",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Baseline h_euler (for particle steps): 1.223e-03\n",
      "H_PARTICLE_STEP_GRID for tuning: [0.0002446, 0.0004891, 0.0007337, 0.0009782, 0.001223, 0.001467, 0.001712, 0.001956, 0.002201, 0.002446]\n",
      "ETA_THETA_STEP_GRID for tuning: [0.05, 0.1, 0.15]\n",
      "\n",
      ">> Tuning PGD...\n",
      "  Tuning PGD over 10 h values...\n",
      "   PGD  -> Optimal h = 2.201e-03\n",
      "\n",
      ">> Tuning JALA-EM...\n",
      "  Tuning JALA-EM over 10 h_part and 3 eta_theta values...\n",
      "   JALA-EM -> Optimal h_part = 2.446e-03, Optimal eta_theta = 5.000e-02\n",
      "\n",
      ">> Tuning SOUL (m_inner = 10)...\n",
      "  Tuning SOUL over 10 gamma and 3 eta values...\n",
      "   SOUL -> Optimal gamma (step_x) = 1.223e-03, Optimal eta (step_theta) = 1.000e-01\n",
      "\n",
      "Running PGD trajectory (h=2.201e-03)...\n",
      "PGD finished: 75137 iters, 5.00s.\n",
      "\n",
      "Running SOUL trajectory (gamma=1.223e-03, eta=1.000e-01, m_inner=10)...\n",
      "SOUL finished: 8439 updates, 5.00s.\n",
      "\n",
      "Running JALA-EM trajectory (h_part=2.446e-03, eta_theta=5.000e-02)...\n",
      "JALA-EM finished: 5420 iters, 5.00s.\n"
     ]
    }
   ],
   "source": [
    "MAX_RUNTIME_SECONDS = 5.0\n",
    "ITERATION_MILESTONE = 200\n",
    "    \n",
    "rng_global = np.random.default_rng(SEED)\n",
    "\n",
    "X_all_data, y_all_data = load_breast_cancer()\n",
    "\n",
    "X_train_val, X_test_final, y_train_val, y_test_final = train_test_split(\n",
    "    X_all_data,\n",
    "    y_all_data,\n",
    "    test_size=cfg.test_fraction,\n",
    "    stratify=y_all_data,\n",
    "    random_state=SEED,\n",
    ")\n",
    "\n",
    "h_euler_step = safe_constant_step(X_train_val, cfg.prior_var, safety=0.99)\n",
    "\n",
    "H_PARTICLE_STEP_GRID = np.linspace(0.1, 1.0, 10) * h_euler_step * 2\n",
    "ETA_THETA_STEP_GRID  = cfg.eta_theta_grid\n",
    "\n",
    "print(f\"Baseline h_euler (for particle steps): {h_euler_step:.3e}\")\n",
    "print(f\"H_PARTICLE_STEP_GRID for tuning: {[float(f'{v:.3e}') for v in H_PARTICLE_STEP_GRID]}\")\n",
    "print(f\"ETA_THETA_STEP_GRID for tuning: {[float(f'{v:.3e}') for v in ETA_THETA_STEP_GRID]}\")\n",
    "\n",
    "kfold_cv = KFold(n_splits=cfg.kfold_splits, shuffle=True, random_state=SEED)\n",
    "\n",
    "print(\"\\nTuning PGD...\")\n",
    "h_star_pgd, _, _ = tune_pgd(\n",
    "    X_train_val, \n",
    "    y_train_val, \n",
    "    H_PARTICLE_STEP_GRID,\n",
    "    n_particles_tune=cfg.particle_count,\n",
    "    rng_tune=np.random.default_rng(SEED+1),\n",
    "    kfold_tune=kfold_cv,\n",
    ")\n",
    "print(f\"PGD -> Optimal h = {h_star_pgd:.3e}\")\n",
    "\n",
    "print(\"\\nTuning JALA-EM...\")\n",
    "(h_star_jala_accurate, eta_star_jala_accurate), _, _ = tune_jala_em(\n",
    "    X_train_val,\n",
    "    y_train_val,\n",
    "    H_PARTICLE_STEP_GRID,\n",
    "    ETA_THETA_STEP_GRID,\n",
    "    n_particles_tune=cfg.particle_count,\n",
    "    rng_tune=np.random.default_rng(SEED+2),\n",
    "    kfold_tune=kfold_cv,\n",
    ")\n",
    "print(f\"JALA-EM -> Optimal h_part = {h_star_jala_accurate:.3e}, Optimal eta_theta = {eta_star_jala_accurate:.3e}\")\n",
    "\n",
    "M_INNER_SOUL = cfg.particle_count\n",
    "print(f\"\\nTuning SOUL (m_inner = {M_INNER_SOUL})...\")\n",
    "(gamma_star_soul, eta_star_soul), _, _ = tune_soul(\n",
    "    X_train_val, \n",
    "    y_train_val,\n",
    "    gamma_grid_tune=H_PARTICLE_STEP_GRID,\n",
    "    eta_grid_tune=ETA_THETA_STEP_GRID,\n",
    "    m_inner_tune=M_INNER_SOUL,\n",
    "    n_particles_tune=cfg.particle_count,\n",
    "    rng_tune=np.random.default_rng(SEED+3),\n",
    "    kfold_tune=kfold_cv,\n",
    ")\n",
    "print(f\"SOUL -> Optimal gamma (step_x) = {gamma_star_soul:.3e}, Optimal eta (step_theta) = {eta_star_soul:.3e}\")\n",
    "\n",
    "if cfg.max_mmle_steps < ITERATION_MILESTONE or cfg.max_pgd_iters < ITERATION_MILESTONE:\n",
    "    print(f\"Warning: ITERATION_MILESTONE ({ITERATION_MILESTONE}) is greater than some max_iters!\")\n",
    "\n",
    "results_plotting = {}\n",
    "\n",
    "print(f\"\\nRunning PGD trajectory (h={h_star_pgd:.3e})...\")\n",
    "theta_pgd, time_pgd, k_pgd, time_mark_pgd, theta_mark_pgd, final_parts_pgd = pgd_const_for_trajectory_timed(\n",
    "    X_train_val, \n",
    "    y_train_val, \n",
    "    step=h_star_pgd, \n",
    "    n_particles=cfg.particle_count,\n",
    "    max_duration_seconds=MAX_RUNTIME_SECONDS, \n",
    "    target_iter_mark=ITERATION_MILESTONE,\n",
    "    rng=np.random.default_rng(SEED+1),\n",
    ")\n",
    "\n",
    "results_plotting['PGD'] = {\n",
    "    'theta': theta_pgd,\n",
    "    'time': time_pgd,\n",
    "    'k': k_pgd,\n",
    "    'time_mark': time_mark_pgd, \n",
    "    'theta_mark': theta_mark_pgd,\n",
    "    'final_parts': final_parts_pgd,\n",
    "    'color': 'C0',\n",
    "}\n",
    "\n",
    "if k_pgd > 0 and time_pgd is not None and len(time_pgd) > 0:\n",
    "    print(f\"PGD finished: {k_pgd} iters, {time_pgd[-1]:.2f}s.\")\n",
    "else: \n",
    "    print(f\"PGD did not complete sufficient steps or timed out early.\")\n",
    "\n",
    "print(f\"\\nRunning SOUL trajectory (gamma={gamma_star_soul:.3e}, eta={eta_star_soul:.3e}, m_inner={M_INNER_SOUL})...\")\n",
    "theta_soul, time_soul, k_soul, time_mark_soul, theta_mark_soul, final_parts_soul = soul_const_for_trajectory_timed(\n",
    "    X_train_val,\n",
    "    y_train_val, \n",
    "    step_x=gamma_star_soul, \n",
    "    step_theta=eta_star_soul, \n",
    "    m_inner=M_INNER_SOUL,\n",
    "    n_particles=cfg.particle_count, \n",
    "    max_duration_seconds=MAX_RUNTIME_SECONDS,\n",
    "    target_iter_mark=ITERATION_MILESTONE, \n",
    "    rng=np.random.default_rng(SEED+2),\n",
    ")\n",
    "\n",
    "results_plotting['SOUL'] = {\n",
    "    'theta': theta_soul, \n",
    "    'time': time_soul, \n",
    "    'k': k_soul,\n",
    "    'time_mark': time_mark_soul, \n",
    "    'theta_mark': theta_mark_soul,\n",
    "    'final_parts': final_parts_soul,\n",
    "    'color': 'C1',\n",
    "}\n",
    "\n",
    "if k_soul > 0 and time_soul is not None and len(time_soul) > 0:\n",
    "    print(f\"SOUL finished: {k_soul} updates, {time_soul[-1]:.2f}s.\")\n",
    "else:\n",
    "    print(f\"SOUL did not complete sufficient steps or timed out early.\")\n",
    "\n",
    "print(f\"\\nRunning JALA-EM trajectory (h_part={h_star_jala_accurate:.3e}, eta_theta={eta_star_jala_accurate:.3e})...\")\n",
    "(theta_jala, time_jala, k_jala, time_mark_jala, theta_mark_jala,\n",
    "ess_before_hist_jala, ess_after_hist_jala, final_parts_jala,\n",
    "final_log_A_jala, resampling_occurred_jala) = jala_em_accurate_for_trajectory_timed(\n",
    "    X_train_val, \n",
    "    y_train_val, \n",
    "    h_part=h_star_jala_accurate, \n",
    "    eta_theta=eta_star_jala_accurate,\n",
    "    n_particles=cfg.particle_count, \n",
    "    max_duration_seconds=MAX_RUNTIME_SECONDS,\n",
    "    target_iter_mark=ITERATION_MILESTONE,\n",
    "    ess_threshold_frac=cfg.ess_fraction,\n",
    "    rng=np.random.default_rng(SEED+3),\n",
    ")\n",
    "\n",
    "results_plotting['JALA-EM'] = {\n",
    "    'theta': theta_jala, \n",
    "    'time': time_jala, \n",
    "    'k': k_jala,\n",
    "    'time_mark': time_mark_jala, \n",
    "    'theta_mark': theta_mark_jala,\n",
    "    'ess_before_hist': ess_before_hist_jala,\n",
    "    'ess_after_hist': ess_after_hist_jala,\n",
    "    'final_parts': final_parts_jala,\n",
    "    'final_log_A': final_log_A_jala,\n",
    "    'resampling_occurred': resampling_occurred_jala,\n",
    "    'color': 'C2'\n",
    "}\n",
    "\n",
    "if k_jala > 0 and time_jala is not None and len(time_jala) > 0:\n",
    "    print(f\"JALA-EM finished: {k_jala} iters, {time_jala[-1]:.2f}s.\")\n",
    "else:\n",
    "    print(f\"JALA-EM did not complete sufficient steps or timed out early.\")\n",
    "\n",
    "DATA_FILENAME = f\"blr_plot_data_cache_N_is_{cfg.particle_count}.json\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "946dec6a",
   "metadata": {},
   "source": [
    "# Save Data for Plotting (Optional to Run)\n",
    "\n",
    "**Should be run if above Experimental Trial cell run!**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8834d24e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved computation results to blr_plot_data_cache_N_is_10.json\n"
     ]
    }
   ],
   "source": [
    "def ndarrays_to_lists_recursive(obj: Any) -> Any:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if isinstance(obj, np.ndarray):\n",
    "        return obj.tolist()\n",
    "    \n",
    "    elif isinstance(obj, dict):\n",
    "        return {k: ndarrays_to_lists_recursive(v) for k, v in obj.items()}\n",
    "    \n",
    "    elif isinstance(obj, list):\n",
    "        return [ndarrays_to_lists_recursive(item) for item in obj]\n",
    "    \n",
    "    return obj\n",
    "\n",
    "results_plotting_serializable = ndarrays_to_lists_recursive(results_plotting)\n",
    "\n",
    "current_cfg_dict = asdict(cfg)\n",
    "\n",
    "if isinstance(current_cfg_dict['eta_theta_grid'], np.ndarray):\n",
    "    current_cfg_dict['eta_theta_grid'] = current_cfg_dict['eta_theta_grid'].tolist()\n",
    "\n",
    "data_to_save = {\n",
    "    \"results_plotting\": results_plotting_serializable,\n",
    "    \"cfg_as_dict\": current_cfg_dict,\n",
    "    \"D_global\": D_global,\n",
    "    \"ITERATION_MILESTONE\": ITERATION_MILESTONE,\n",
    "    \"MAX_RUNTIME_SECONDS\": MAX_RUNTIME_SECONDS,\n",
    "}\n",
    "\n",
    "try:\n",
    "    with open(DATA_FILENAME, 'w') as f:\n",
    "        json.dump(data_to_save, f, indent=4)\n",
    "    print(f\"Saved computation results to {DATA_FILENAME}\")\n",
    "    \n",
    "except Exception as e:\n",
    "    print(f\"Error saving data: {e}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c3b0171",
   "metadata": {},
   "source": [
    "# Plotting Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0d02af9",
   "metadata": {},
   "outputs": [],
   "source": [
    "pgd_color = '#003f5c'\n",
    "soul_color = '#ffa600'\n",
    "jala_em_color_key_name = 'JALA-EM'\n",
    "jala_em_color = '#bc5090'\n",
    "\n",
    "\n",
    "def update_colors_in_results(results_dict: Dict[str, Dict[str, Any]]):\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    if 'PGD' in results_dict:\n",
    "        results_dict['PGD']['color'] = pgd_color\n",
    "\n",
    "    if 'SOUL' in results_dict:\n",
    "        results_dict['SOUL']['color'] = soul_color\n",
    "\n",
    "    if jala_em_color_key_name in results_dict: \n",
    "        results_dict[jala_em_color_key_name]['color'] = jala_em_color\n",
    "\n",
    "\n",
    "def generate_comparison_figure(\n",
    "    results_data: Dict[str, Dict[str, Any]],\n",
    "    iter_milestone: int,\n",
    "    max_runtime: float,\n",
    "    d_dim: int,\n",
    "    jala_em_dict_key: str,\n",
    "    ax1_xscale_type: str = 'linear',\n",
    "    ax1_symlog_linscale: float = 0.3,\n",
    "    fig_filename_suffix: str = '',\n",
    "    figsize: tuple = (10, 3.5),\n",
    "    font_options: Optional[Dict[str, Union[int, float]]] = None,\n",
    "    line_options: Optional[Dict[str, Union[int, float]]] = None,\n",
    "    ):\n",
    "    \"\"\"\n",
    "    TODO: Clean up logic below!\n",
    "    \"\"\"\n",
    "\n",
    "    # Font Styling\n",
    "    rc_params_to_update = {\n",
    "        \"text.usetex\": True,\n",
    "        \"font.family\": \"serif\",\n",
    "        \"font.serif\": [\"Computer Modern Roman\"],\n",
    "        \"font.size\": 20,\n",
    "        \"axes.labelsize\": 20,\n",
    "        \"axes.titlesize\": 20,\n",
    "        \"xtick.labelsize\": 18,\n",
    "        \"ytick.labelsize\": 18,\n",
    "        \"legend.fontsize\": 20,\n",
    "    }\n",
    "    if font_options:\n",
    "        rc_params_to_update[\"font.size\"] = font_options.get(\"default\", rc_params_to_update[\"font.size\"])\n",
    "        rc_params_to_update[\"axes.labelsize\"] = font_options.get(\"axes_label\", rc_params_to_update[\"axes.labelsize\"])\n",
    "        rc_params_to_update[\"axes.titlesize\"] = font_options.get(\"axes_title\", rc_params_to_update[\"axes.titlesize\"])\n",
    "        rc_params_to_update[\"xtick.labelsize\"] = font_options.get(\"xtick_label\", rc_params_to_update[\"xtick.labelsize\"])\n",
    "        rc_params_to_update[\"ytick.labelsize\"] = font_options.get(\"ytick_label\", rc_params_to_update[\"ytick.labelsize\"])\n",
    "        rc_params_to_update[\"legend.fontsize\"] = font_options.get(\"legend\", rc_params_to_update[\"legend.fontsize\"])\n",
    "\n",
    "    # Line Styling\n",
    "    lw_config = {\n",
    "        'main_trace': 1.5,\n",
    "        'milestone_marker_edge': 0.7,\n",
    "        'milestone_vline': 1.0,\n",
    "        'kde_trace': 1.5,\n",
    "        'grid_line': plt.rcParams.get('grid.linewidth', 0.8)\n",
    "    }\n",
    "    if line_options:\n",
    "        for key, value in line_options.items():\n",
    "            if key in lw_config:\n",
    "                lw_config[key] = float(value)\n",
    "\n",
    "    rc_params_to_update[\"grid.linewidth\"] = lw_config['grid_line']\n",
    "\n",
    "    try:\n",
    "        plt.rcParams.update(bundles.neurips2023())\n",
    "        plt.rcParams.update(rc_params_to_update)\n",
    "\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: Using tueplots failed: {e}!\")\n",
    "        plt.rcParams.update(rc_params_to_update)\n",
    "\n",
    "\n",
    "    fig, axes = plt.subplots(1, 2, figsize=figsize)\n",
    "\n",
    "    fig_legend_handles: List[Any] = []\n",
    "    milestone_proxy_handle = None\n",
    "\n",
    "    # \\theta vs time\n",
    "    ax1 = axes[0]\n",
    "    symlog_threshold_ax1 = 5e-1\n",
    "\n",
    "    for name, data in results_data.items():\n",
    "        if data.get('time') is not None and data.get('theta') is not None and len(data['time']) > 1:\n",
    "            line, = ax1.plot(\n",
    "                data['time'], data['theta'], \n",
    "                label=name, \n",
    "                color=data.get('color', 'gray'),\n",
    "                alpha=0.85, \n",
    "                linewidth=lw_config['main_trace']\n",
    "            )\n",
    "            ax1.plot(\n",
    "                data['time'][0], data['theta'][0], \n",
    "                '.', \n",
    "                markersize=8, \n",
    "                color=data.get('color', 'gray'), \n",
    "                zorder=11, \n",
    "                alpha=0.9\n",
    "            )\n",
    "\n",
    "            if not any(h.get_label() == name for h in fig_legend_handles):\n",
    "                 fig_legend_handles.append(line)\n",
    "\n",
    "            if data.get('k', 0) >= iter_milestone and data.get('time_mark') is not None and data.get('theta_mark') is not None:\n",
    "                ax1.plot(\n",
    "                    data['time_mark'], data['theta_mark'], \n",
    "                    'o',\n",
    "                    color=data.get('color', 'gray'), \n",
    "                    markersize=8,\n",
    "                    markeredgecolor='k', \n",
    "                    mew=lw_config['milestone_marker_edge'], \n",
    "                    zorder=10\n",
    "                )\n",
    "                if milestone_proxy_handle is None :\n",
    "                    milestone_proxy_handle = plt.Line2D(\n",
    "                        [0], [0], \n",
    "                        linestyle='None', \n",
    "                        color='darkgrey',\n",
    "                        marker='o', \n",
    "                        markerfacecolor='darkgrey',\n",
    "                        markeredgecolor='k', \n",
    "                        mew=lw_config['milestone_marker_edge'], \n",
    "                        markersize=8,\n",
    "                        label=f'{iter_milestone} Iter.'\n",
    "                    )\n",
    "\n",
    "    ax1.autoscale_view()\n",
    "    ymin_plot1_auto, ymax_plot1_auto = ax1.get_ylim()\n",
    "\n",
    "    for name, data in results_data.items():\n",
    "         if data.get('k', 0) >= iter_milestone and data.get('time_mark') is not None and data.get('theta_mark') is not None:\n",
    "            if data['theta_mark'] >= ymin_plot1_auto and data['theta_mark'] <= ymax_plot1_auto:\n",
    "                 ax1.vlines(\n",
    "                     data['time_mark'], \n",
    "                     ymin=ymin_plot1_auto, ymax=data['theta_mark'],\n",
    "                    color=data.get('color', 'gray'), \n",
    "                    linestyle=':', \n",
    "                    alpha=0.6,\n",
    "                    linewidth=lw_config['milestone_vline'],\n",
    "                )\n",
    "                 \n",
    "    ax1.set_ylim(ymin_plot1_auto, ymax_plot1_auto)\n",
    "\n",
    "    ax1.set_xlabel(\"Time (s)\")\n",
    "    ax1.set_ylabel(r\"$\\theta$\")\n",
    "\n",
    "    ax1.grid(True, linestyle=':', alpha=0.4)\n",
    "\n",
    "    desired_right_limit_ax1 = max_runtime * 1.03\n",
    "\n",
    "    def get_custom_symlog_formatter(max_val_for_integer_display: float):\n",
    "\n",
    "        def custom_symlog_format(x: float, pos: Any) -> str:\n",
    "\n",
    "            if np.isclose(x,0):\n",
    "                return '0'\n",
    "            \n",
    "            if x >= 0.1 and np.isclose(x, round(x, 2)) and x <= max_val_for_integer_display:\n",
    "                 \n",
    "                 if np.isclose(x % 1, 0):\n",
    "                    return f'{int(round(x))}'\n",
    "                 if np.isclose(x * 10 % 1, 0):\n",
    "                    return f'{x:.1f}'\n",
    "                 return f'{x:.2g}'\n",
    "            \n",
    "            if x < 1 and x > 0:\n",
    "                 log10_x = np.log10(x)\n",
    "\n",
    "                 if np.isclose(log10_x, round(log10_x)):\n",
    "                    return f'$10^{{{int(round(log10_x))}}}$'\n",
    "                 else:\n",
    "                    return f'{x:.2g}'\n",
    "                 \n",
    "            return f'{x:.1f}'.rstrip('0').rstrip('.') if x % 1 != 0 else str(int(x))\n",
    "        \n",
    "        return custom_symlog_format\n",
    "\n",
    "    if ax1_xscale_type == 'symlog':\n",
    "        ax1.set_xscale('symlog', linthresh=symlog_threshold_ax1, linscale=ax1_symlog_linscale)\n",
    "        ax1.set_xlim(left=0, right=desired_right_limit_ax1)\n",
    "\n",
    "        major_ticks_symlog_ax1_base = [0.1, 1, max_runtime]\n",
    "\n",
    "        if max_runtime > 1:\n",
    "            for i in range(2, int(max_runtime) + 1):\n",
    "                 if i not in major_ticks_symlog_ax1_base:\n",
    "                    major_ticks_symlog_ax1_base.append(float(i))\n",
    "\n",
    "        major_ticks_symlog_ax1 = sorted(list(set(major_ticks_symlog_ax1_base)))\n",
    "        ax1_current_xlim = ax1.get_xlim()\n",
    "\n",
    "        major_ticks_symlog_ax1 = [tick for tick in major_ticks_symlog_ax1 if tick >= (ax1_current_xlim[0] if ax1_current_xlim[0] is not None else 0) and tick <= (ax1_current_xlim[1] if ax1_current_xlim[1] is not None else max_runtime)]\n",
    "\n",
    "        if ax1_current_xlim[0] == 0 and 0 not in major_ticks_symlog_ax1:\n",
    "            major_ticks_symlog_ax1 = [0.0] + major_ticks_symlog_ax1\n",
    "\n",
    "        major_ticks_symlog_ax1 = sorted(list(set(major_ticks_symlog_ax1)))\n",
    "\n",
    "        ax1.set_xticks(major_ticks_symlog_ax1)\n",
    "        ax1.xaxis.set_major_formatter(mticker.FuncFormatter(get_custom_symlog_formatter(max_runtime)))\n",
    "\n",
    "    else:\n",
    "        ax1.set_xlim(left=-0.01 * max_runtime, right=desired_right_limit_ax1)\n",
    "        current_ticks_ax1 = list(ax1.get_xticks())\n",
    "        \n",
    "        if max_runtime not in current_ticks_ax1 and not any(np.isclose(max_runtime, tick) for tick in current_ticks_ax1):\n",
    "            if ax1.get_xlim()[0] <= max_runtime <= ax1.get_xlim()[1]:\n",
    "                 current_ticks_ax1.append(max_runtime)\n",
    "\n",
    "        current_ticks_ax1 = [tick for tick in current_ticks_ax1 if tick >=0 and tick <= desired_right_limit_ax1]\n",
    "\n",
    "        current_ticks_ax1 = sorted(list(set(current_ticks_ax1)))\n",
    "\n",
    "        if current_ticks_ax1 and current_ticks_ax1[0] < 0 and np.isclose(current_ticks_ax1[0],0):\n",
    "            current_ticks_ax1[0] = 0.0\n",
    "\n",
    "        ax1.set_xticks(current_ticks_ax1)\n",
    "        ax1.xaxis.set_major_formatter(mticker.ScalarFormatter())\n",
    "\n",
    "\n",
    "    # KDE Plot\n",
    "    ax2 = axes[1]\n",
    "\n",
    "    all_kde_x_coords = []\n",
    "    plotted_kdes = {}\n",
    "    max_kde_y_value = 0\n",
    "\n",
    "    for name, data in results_data.items():\n",
    "        final_parts = data.get('final_parts')\n",
    "        if final_parts is not None and d_dim >= 2 and final_parts.shape[0] >= 2 and final_parts.shape[1] > 1:\n",
    "            data_for_kde = final_parts[1, :]\n",
    "            weights_for_kde = None\n",
    "            current_color = data.get('color', 'gray')\n",
    "            if name == jala_em_dict_key:\n",
    "                final_log_A = data.get('final_log_A')\n",
    "                if final_log_A is not None and len(final_log_A) == len(data_for_kde):\n",
    "                    log_A_safe = np.nan_to_num(final_log_A, nan=-np.inf, neginf=-np.inf)\n",
    "                    if not np.all(np.isneginf(log_A_safe)):\n",
    "                        lse_A = logsumexp(log_A_safe)\n",
    "                        if np.isfinite(lse_A):\n",
    "                            weights_for_kde = np.exp(log_A_safe - lse_A)\n",
    "                            if not (np.all(np.isfinite(weights_for_kde)) and \\\n",
    "                                    np.all(weights_for_kde >= 0) and \\\n",
    "                                    np.isclose(np.sum(weights_for_kde), 1.0, atol=1e-5) and \\\n",
    "                                    np.sum(weights_for_kde) > 1e-9 ) :\n",
    "                                weights_for_kde = None\n",
    "                        else: weights_for_kde = None\n",
    "                    else: weights_for_kde = None\n",
    "\n",
    "            if len(np.unique(data_for_kde)) > 1 :\n",
    "                try:\n",
    "                    kde_obj = gaussian_kde(data_for_kde, weights=weights_for_kde)\n",
    "                    mean_kde_val = np.average(data_for_kde, weights=weights_for_kde) if weights_for_kde is not None and np.sum(weights_for_kde) > 0 else np.mean(data_for_kde)\n",
    "                    var_kde_val = np.average((data_for_kde - mean_kde_val) ** 2, weights=weights_for_kde) if weights_for_kde is not None and np.sum(weights_for_kde) > 0 else np.var(data_for_kde)\n",
    "                    std_kde_val = np.sqrt(var_kde_val) if var_kde_val > 1e-9 else 0.1\n",
    "                    x_kde_min = data_for_kde.min() - 1.5 * std_kde_val\n",
    "                    x_kde_max = data_for_kde.max() + 1.5 * std_kde_val\n",
    "                    if np.isclose(x_kde_min, x_kde_max) or x_kde_min > x_kde_max:\n",
    "                        x_kde_min = data_for_kde.min() - 0.5\n",
    "                        x_kde_max = data_for_kde.max() + 0.5\n",
    "\n",
    "                    if np.isclose(x_kde_min, x_kde_max):\n",
    "                        x_kde_min -=0.5\n",
    "                        x_kde_max +=0.5\n",
    "\n",
    "                    x_kde = np.linspace(x_kde_min, x_kde_max, 200)\n",
    "                    kde_values = kde_obj(x_kde)\n",
    "                    plotted_kdes[name] = (x_kde, kde_values, current_color)\n",
    "                    all_kde_x_coords.extend(x_kde)\n",
    "\n",
    "                    if len(kde_values) > 0:\n",
    "                        max_kde_y_value = max(max_kde_y_value, np.max(kde_values))\n",
    "\n",
    "                except Exception as e:\n",
    "                    print(f\"KDE plot error for {name}: {e}.\")\n",
    "\n",
    "        elif final_parts is None:\n",
    "            print(f\"KDE plot skipped for {name}: `final_parts` is None.\")\n",
    "\n",
    "\n",
    "    if plotted_kdes:\n",
    "        if all_kde_x_coords:\n",
    "            global_x_kde_min = min(all_kde_x_coords)\n",
    "            global_x_kde_max = max(all_kde_x_coords)\n",
    "\n",
    "            ax2.set_xlim(global_x_kde_min, global_x_kde_max)\n",
    "\n",
    "        for name, (x_kde, kde_values, current_color) in plotted_kdes.items():\n",
    "            ax2.plot(x_kde, kde_values, color=current_color, linewidth=lw_config['kde_trace'])\n",
    "            ax2.fill_between(x_kde, kde_values, alpha=0.25, color=current_color)\n",
    "\n",
    "        if max_kde_y_value > 0:\n",
    "             ax2.set_ylim(bottom=0, top=max_kde_y_value * 1.1)\n",
    "        else:\n",
    "             ax2.set_ylim(bottom=0, top=1.0)\n",
    "    else:\n",
    "        ax2.text(0.5,0.5, \"No KDE data\", ha='center', va='center', transform=ax2.transAxes)\n",
    "\n",
    "    ax2.set_xlabel(r\"$w_2$\")\n",
    "    ax2.set_ylabel(\"KDE\")\n",
    "\n",
    "    ax2.grid(True, linestyle=':', alpha=0.4)\n",
    "\n",
    "    ax2.yaxis.set_major_locator(mticker.MaxNLocator(nbins=5, prune='upper'))\n",
    "    ax2.tick_params(axis='y', labelleft=True)\n",
    "    ax2.yaxis.set_major_formatter(mticker.FormatStrFormatter('%.2f'))\n",
    "\n",
    "    # Legend\n",
    "    if milestone_proxy_handle:\n",
    "        current_labels_in_legend = [h.get_label() for h in fig_legend_handles]\n",
    "        if milestone_proxy_handle.get_label() not in current_labels_in_legend:\n",
    "            fig_legend_handles.append(milestone_proxy_handle)\n",
    "\n",
    "    if fig_legend_handles:\n",
    "        legend_ncol = len(fig_legend_handles)\n",
    "        \n",
    "        fig.legend(\n",
    "            handles=fig_legend_handles,\n",
    "            loc='lower center', \n",
    "            ncol=legend_ncol,\n",
    "            bbox_to_anchor=(0.5, 0.05),\n",
    "            frameon=False\n",
    "        )\n",
    "\n",
    "    fig.tight_layout(rect=[0, 0.10 if figsize[1] < 4.5 else 0.15, 1, 0.98])\n",
    "    base_filename = \"final\"\n",
    "\n",
    "    if fig_filename_suffix:\n",
    "        base_filename += f\"_{fig_filename_suffix}\"\n",
    "\n",
    "    try:\n",
    "        fig.savefig(f\"{base_filename}.pdf\", bbox_inches='tight', pad_inches=0.05)\n",
    "        print(f\"Plot saved as {base_filename}.pdf\")\n",
    "    except Exception as e: \n",
    "        print(f\"Error saving plot {base_filename}: {e}\")\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ef56806e",
   "metadata": {},
   "source": [
    "# Load Saved Data & Plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30d6cfce",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Successfully loaded data from blr_plot_data_cache_N_is_10.json\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/p7/j8d1ct3n6r5b879xs9vhfkfh0000gn/T/ipykernel_8963/2160968712.py:331: UserWarning: The figure layout has changed to tight\n",
      "  fig.tight_layout(rect=[0, 0.10 if figsize[1] < 4.5 else 0.15, 1, 0.98])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Plot saved as final_blr_N_equals_10_final.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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vFytUZTIQwYREREREWW2NWvWqC2HGRggIoqPwQEiIsrKm31JVZSK1gNSo0gCBKlsiUBEREREROkhLQ0k9ZC+4o/c7zN9KBFRV+xzgIiIsjInqfQjIH0K9DbIwMAAEREREVHutDKuq6vrEhiI1WcZEVG+Y8sBIiLKWlo/AT1pLtyb7xIRERERUWaR1gLSl9jixYsNw6UikFQqkspFRERkxOAAERFlfe0gaSKcbP8DUntIOjgjIiIiIqLsJ/2ISSsBMyz6IiIyx+AAEREREREREREREVGeYZ8DRERERERERERERER5hsEBIiIiIiIiIiIiIqI8w+AAEREREREREREREVGeYXCAiIiIiIiIiIiIiCjPMDhARERERERERERERJRnGBwgIiIiIiIiIiIiIsozDA4QEREREREREREREeUZBgeIiIiIiIiIiIiIiPIMgwNERERERERERERERHmGwQEiIiIiIiIiIiIiojzD4AARERERERERERERUZ5hcICIiIiIiIiIiIiIKM8wOEBERERERERERERElGcYHCAiIiIiIiIiIiIiyjMMDhARERERERERERER5RkGB4iIiIiIiIiIiIiI8gyDA0REREREREREREREeYbBASIiIiIiIiIiIiKiPMPgABERERERERERERFRnmFwgIiIiIiIiIiIiIgozzA4QERERERERERERESUZxgcICIiIiIiIiIiIiLKMwwOEBERERERERERERHlGQYHiIiIiIiIiIiIiIjyDIMDRERERERERERERER5hsEBIiIiIiIiIiIiIqI8w+AAEREREREREREREVGeYXCAiIiIiIiIiIiIiCjPMDhARERERERERERERJRnGBwgIiIiIiIiIiIiIsozDA4QEREREREREREREeUZBgeIiIiIiIiIiIiIiPIMgwNERERERERERERERHmGwQEiIiIiIiIiIiIiojzD4AARERERERERERERUZ5hcICIiIiIiIiIiIiIKM8wOEBERERERERERERElGcYHCAiIiIiIiIiIiIiyjMMDhARERERERERERER5RkGB4iIiIiIiIiIiIiI8gyDA0REREREREREREREeYbBASIiIqI81NDQgL1796Z7NoiIiIiIiChNGBwgIqKctmHDBsyfPx+KosR8jRs3DgsXLsSaNWsSmuamTZuwdOlS9Xvl5eXqNOR9xowZ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N+U8Jn/rr9P6Yyf6ZXa9jDdOP15+j4iIsg+DA0RElNOkoEdfEKIvNO1pobs8iMnDnBR4aA+Z8i7TlAcueRDTPwBq9AWqsV766UjBCYMClCzZZ2Q/kn1U9n3Zn/T7qQyTfSuZY0j2R61gXzt+ZJiMS5YW/DKbXrwgQ3TQLJlXT+aT8uuY0QrvtGMkel+UfUi/z8r53yx4oJHv64MO+u/JuFTsz6mep0T0Zr61847ZNMzmXbaLfC6adv01W454y0/5Tbs2JrKvxguaafuvnDPkXV6xAlip+F708Wu2DNo9o0buQbVjJNbxrc1PvPOeHE/6c4wWIIi+pmrB/WTuLYiIKHMo8r90t14gIiIiIiIiIiIiIqL+wz4HiIiIiIiIiIiIiIjyDIMDRERERERERERERER5hsEBIiIiIiIiIiIiIqI8w+AAEREREREREREREVGeYXCAiIiIiIiIiIiIiCjPMDhARERERERERERERJRnGBwgIiIiIiIiIiIiIsozDA4QEREREREREREREeUZBgeIiIiIiIiIiIiIiPIMgwNERERERERERERERHmGwQEiIiIiIiIiIiIiojzD4AARERERERERERERUZ5hcICIiIiIiIiIiIiIKM8wOEBERERERERERERElGcYHCAiIiIiIiIiIiIiyjMMDhARERERERERERER5RkGB4iIiIiIiIiIiIiIkF/+PwG7EdHCtsAvAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1600x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "@dataclass\n",
    "class ConfigPlaceholder:\n",
    "    particle_count: int = 100\n",
    "    ess_fraction: float = 0.5\n",
    "    eta_theta_grid: List[float] = field(default_factory=list)\n",
    "    def __init__(self, **kwargs):\n",
    "        for key, value in kwargs.items():\n",
    "            setattr(self, key, value)\n",
    "\n",
    "\n",
    "def convert_lists_to_numpy_in_results(results_dict: Dict[str, Dict[str, Any]]) -> Dict[str, Dict[str, Any]]:\n",
    "    \"\"\"\n",
    "    TODO\n",
    "    \"\"\"\n",
    "    converted_results = {}\n",
    "    for method_name, data_dict in results_dict.items():\n",
    "        converted_data = data_dict.copy()\n",
    "\n",
    "        for key, value in data_dict.items():\n",
    "            if key in ['time', 'theta', 'final_parts', 'final_log_A', 'ess_after_hist', 'resampling_occurred']:\n",
    "                if value is not None:\n",
    "                    try:\n",
    "                        converted_data[key] = np.asarray(value)\n",
    "                    except Exception as e:\n",
    "                        print(f\"Warning: Could not convert {key} for {method_name} to ndarray: {e}. Value: {value}\")\n",
    "                        converted_data[key] = value\n",
    "                else:\n",
    "                    converted_data[key] = None\n",
    "\n",
    "        converted_results[method_name] = converted_data\n",
    "\n",
    "    return converted_results\n",
    "\n",
    "\n",
    "DATA_FILENAME_TO_LOAD = DATA_FILENAME\n",
    "\n",
    "try:\n",
    "    with open(DATA_FILENAME_TO_LOAD, 'r') as f:\n",
    "        loaded_data_from_json = json.load(f)\n",
    "    print(f\"Successfully loaded data from {DATA_FILENAME_TO_LOAD}\")\n",
    "\n",
    "except FileNotFoundError:\n",
    "    print(f\"Error: File {DATA_FILENAME_TO_LOAD} not found.\")\n",
    "    exit()\n",
    "\n",
    "except json.JSONDecodeError:\n",
    "    print(f\"Error: Could not decode JSON from {DATA_FILENAME_TO_LOAD}.\")\n",
    "    exit()\n",
    "\n",
    "except Exception as e:\n",
    "    print(f\"An unexpected error occurred while loading data: {e}\")\n",
    "    exit()\n",
    "\n",
    "results_plotting_loaded_lists = loaded_data_from_json.get(\"results_plotting\")\n",
    "cfg_as_dict_loaded = loaded_data_from_json.get(\"cfg_as_dict\")\n",
    "D_loaded = loaded_data_from_json.get(\"D_global\")\n",
    "ITERATION_MILESTONE_loaded = loaded_data_from_json.get(\"ITERATION_MILESTONE\")\n",
    "MAX_RUNTIME_SECONDS_loaded = loaded_data_from_json.get(\"MAX_RUNTIME_SECONDS\")\n",
    "\n",
    "if None in [results_plotting_loaded_lists, cfg_as_dict_loaded, D_loaded, ITERATION_MILESTONE_loaded, MAX_RUNTIME_SECONDS_loaded]:\n",
    "    print(\"Error: One or more essential keys are missing from the loaded JSON data!\")\n",
    "    exit()\n",
    "\n",
    "try:\n",
    "    cfg_reloaded = ConfigPlaceholder(**cfg_as_dict_loaded)\n",
    "    if 'eta_theta_grid' in cfg_as_dict_loaded and isinstance(cfg_as_dict_loaded['eta_theta_grid'], list):\n",
    "            cfg_reloaded.eta_theta_grid = cfg_as_dict_loaded['eta_theta_grid']\n",
    "\n",
    "except TypeError as e:\n",
    "    print(f\"Error: {e}\")\n",
    "    print(\"cfg_as_dict_loaded keys:\", cfg_as_dict_loaded.keys())\n",
    "    cfg_reloaded = SimpleNamespace(**cfg_as_dict_loaded)\n",
    "\n",
    "\n",
    "results_plotting_reloaded_np = convert_lists_to_numpy_in_results(results_plotting_loaded_lists)\n",
    "\n",
    "# Update colors\n",
    "update_colors_in_results(results_plotting_reloaded_np)\n",
    "\n",
    "D_global = D_loaded\n",
    "ITERATION_MILESTONE = ITERATION_MILESTONE_loaded\n",
    "MAX_RUNTIME_SECONDS = MAX_RUNTIME_SECONDS_loaded\n",
    "\n",
    "# Plotting customisation!\n",
    "custom_font_options_reloaded = {\n",
    "    \"default\": 20, \n",
    "    \"axes_label\": 20, \n",
    "    \"axes_title\": 20,\n",
    "    \"xtick_label\": 18, \n",
    "    \"ytick_label\": 18, \n",
    "    \"legend\": 20,\n",
    "}\n",
    "custom_line_options_reloaded = {\n",
    "    \"main_trace\": 3.0, \n",
    "    \"milestone_marker_edge\": 1.5, \n",
    "    \"milestone_vline\": 2.0,\n",
    "    \"ess_threshold_line\": 2.0, \n",
    "    \"kde_trace\": 3.0, \n",
    "    \"grid_line\": 2.0,\n",
    "}\n",
    "\n",
    "generate_comparison_figure(\n",
    "    results_data=results_plotting_reloaded_np,\n",
    "    iter_milestone=ITERATION_MILESTONE_loaded,\n",
    "    max_runtime=MAX_RUNTIME_SECONDS_loaded,\n",
    "    d_dim=D_loaded,\n",
    "    jala_em_dict_key=jala_em_color_key_name,\n",
    "    ax1_xscale_type='symlog',\n",
    "    ax1_symlog_linscale=0.35,\n",
    "    fig_filename_suffix=f\"blr_N_equals_{cfg.particle_count}_final\",\n",
    "    figsize=(16, 6.0),\n",
    "    font_options=custom_font_options_reloaded,\n",
    "    line_options=custom_line_options_reloaded,\n",
    ")\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "daa25af7",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "152e8ad6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18b80589",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f2c316ea",
   "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.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
