{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2fe26b29",
   "metadata": {},
   "source": [
    "# Reward Tuning of Langevin Processes"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "18249ced",
   "metadata": {},
   "source": [
    "The following serves as an illustrative example for the reward tuning of Langevin processs for the $\\mathrm{ImpDiff}$, $\\mathrm{SOSMC}$-$\\mathrm{ULA}$, and $\\mathrm{SOUL}$. The code is intended for anonymous peer review.\n",
    "\n",
    "**Note: The following was run on the CPU of personal laptop. We provide code for all experiments conducted within the paper upon publication**"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d7f315aa",
   "metadata": {},
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d33dca52",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import matplotlib.pyplot as plt\n",
    "import functools\n",
    "from functools import partial\n",
    "import optax\n",
    "import time\n",
    "from typing import Any, Callable, NamedTuple, Tuple, Optional\n",
    "import functools\n",
    "from itertools import cycle"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b491bf01",
   "metadata": {},
   "source": [
    "The following code leverages `JAX`, and can be simply run on a local CPU device."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e077f38e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[CpuDevice(id=0)]\n"
     ]
    }
   ],
   "source": [
    "print(jax.devices())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "93debf42",
   "metadata": {},
   "source": [
    "### Utility Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b78d7dc3",
   "metadata": {},
   "outputs": [],
   "source": [
    "def build_optimiser(\n",
    "    optimiser_name: str = \"sgd\",\n",
    "    optimiser_kwargs: dict = None,\n",
    "    default_learning_rate: float = None,\n",
    "):\n",
    "    \"\"\"\n",
    "    Build optax optimiser, based on passed `optimiser_name` and `optimiser_kwargs`.\n",
    "    \"\"\"\n",
    "    OPTIMISER_MAP = {\n",
    "        \"sgd\": optax.sgd,\n",
    "        \"adam\": optax.adam,\n",
    "        \"adamw\": optax.adamw,\n",
    "        \"rmsprop\": optax.rmsprop,\n",
    "    }\n",
    "\n",
    "    if optimiser_kwargs is None:\n",
    "        optimiser_kwargs = {}\n",
    "\n",
    "    name = optimiser_name.lower().strip()\n",
    "    factory = OPTIMISER_MAP.get(name)\n",
    "    if factory is None:\n",
    "        raise ValueError(\n",
    "            f\"Unknown optimiser_name={optimiser_name}. \"\n",
    "            f\"The following are currently supported: {sorted(OPTIMISER_MAP.keys())}\"\n",
    "        )\n",
    "\n",
    "    kw = dict(optimiser_kwargs)\n",
    "    for alias in (\"lr\", \"eta\"):\n",
    "        if alias in kw and \"learning_rate\" not in kw:\n",
    "            kw[\"learning_rate\"] = kw.pop(alias)\n",
    "\n",
    "    if \"learning_rate\" not in kw:\n",
    "        if default_learning_rate is None:\n",
    "            raise ValueError(\n",
    "                \"No learning rate provided!\"\n",
    "            )\n",
    "        kw[\"learning_rate\"] = default_learning_rate\n",
    "\n",
    "    return factory(**kw)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ca0b4ead",
   "metadata": {},
   "source": [
    "### Plotting Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "bad34e82",
   "metadata": {},
   "outputs": [],
   "source": [
    "COLOR_MAP = {\n",
    "    'Standard': '#003f5c',\n",
    "    'SOSMC': '#bc5090',\n",
    "    'SOUL': '#ffa600',\n",
    "}\n",
    "\n",
    "def get_color(name):\n",
    "    for key, color in COLOR_MAP.items():\n",
    "        if key in name:\n",
    "            return color\n",
    "    return 'black'\n",
    "\n",
    "def plot_results(results_dict, plot_x_axis: str = 'time', lamb_kl: float = 0.1):\n",
    "    \"\"\"\n",
    "    Plots history of experiment trial.\n",
    "    \"\"\"\n",
    "    colors = ['blue', 'red', 'green', 'orange', 'purple', 'brown', 'pink', 'gray', 'olive', 'cyan']\n",
    "    linestyles = ['-', '--', '-.', ':']\n",
    "    \n",
    "    color_cycle = cycle(colors)\n",
    "    linestyle_cycle = cycle(linestyles)\n",
    "    \n",
    "    algorithm_styles = {}\n",
    "    for name in results_dict.keys():\n",
    "        algorithm_styles[name] = {\n",
    "            'color': next(color_cycle),\n",
    "            'linestyle': next(linestyle_cycle)\n",
    "        }\n",
    "    \n",
    "    fig, axes = plt.subplots(1, 3, figsize=(12, 6))\n",
    "    fig.suptitle('Algorithm Comparison', fontsize=16, y=0.995)\n",
    "    \n",
    "    def get_x_data(res, name):\n",
    "        x_label = plot_x_axis\n",
    "        if plot_x_axis == 'time':\n",
    "            if 'time' in res:\n",
    "                x_data = res['time']\n",
    "                x_label = 'Time (s)'\n",
    "            else:\n",
    "                print(f\"Warning: 'time' not in results for {name}. Plotting by iteration instead!\")\n",
    "                x_data = np.arange(len(res['reward']))\n",
    "                x_label = 'Iteration'\n",
    "        else:\n",
    "            x_data = np.arange(len(res['reward']))\n",
    "            x_label = 'Iteration'\n",
    "        return x_data, x_label\n",
    "    \n",
    "    # Reward\n",
    "    ax = axes[0]\n",
    "    for name, res in results_dict.items():\n",
    "        x_data, x_label = get_x_data(res, name)\n",
    "        style = algorithm_styles[name]\n",
    "        ax.plot(x_data, res['reward'], label=name, \n",
    "                linestyle=style['linestyle'], color=style['color'], alpha=0.7)\n",
    "    ax.set_xlabel(x_label)\n",
    "    ax.set_ylabel('Average Reward')\n",
    "    ax.set_title('Reward Convergence')\n",
    "    ax.legend(fontsize=8)\n",
    "    ax.grid(True, alpha=0.3)\n",
    "    \n",
    "    # KL Norm\n",
    "    ax = axes[1]\n",
    "    for name, res in results_dict.items():\n",
    "        x_data, x_label = get_x_data(res, name)\n",
    "        style = algorithm_styles[name]\n",
    "        ax.plot(x_data, res['kl'], label=name,\n",
    "                linestyle=style['linestyle'], color=style['color'], alpha=0.7)\n",
    "    ax.set_xlabel(x_label)\n",
    "    ax.set_ylabel('KL Gradient Norm')\n",
    "    ax.set_title('KL Norm')\n",
    "    ax.legend(fontsize=8)\n",
    "    ax.grid(True, alpha=0.3)\n",
    "    \n",
    "    # Net Objective\n",
    "    ax = axes[2]\n",
    "    for name, res in results_dict.items():\n",
    "        x_data, x_label = get_x_data(res, name)\n",
    "        style = algorithm_styles[name]\n",
    "        ax.plot(x_data, res['nll'], label=name,\n",
    "                linestyle=style['linestyle'], color=style['color'], alpha=0.7)\n",
    "    ax.set_xlabel(x_label)\n",
    "    ax.set_ylabel('NLL Proxy')\n",
    "    ax.set_title(f'NLL Proxy')\n",
    "    ax.legend(fontsize=8)\n",
    "    ax.grid(True, alpha=0.3)\n",
    "    \n",
    "    plt.tight_layout(rect=[0, 0.03, 1, 0.97])\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4614099",
   "metadata": {},
   "source": [
    "# Reward and Potential Defintions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2da4ffac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Original Code (As seen here: https://github.com/google-deepmind/implicit_diffusion)\n",
    "# Note some of the original code has been adapted!\n",
    "\n",
    "def gmm_energy(\n",
    "    x: jnp.ndarray,\n",
    "    theta: jnp.ndarray,\n",
    "    means: jnp.ndarray,\n",
    "    sig_sq: float,\n",
    "):\n",
    "  \"\"\"\n",
    "  Generalised version of `gmm_energy` from: https://github.com/google-deepmind/implicit_diffusion\n",
    "  \"\"\"\n",
    "  v = jax.nn.softmax(theta)\n",
    "  \n",
    "  sq_distances = jnp.sum((x - means) ** 2, axis=1)\n",
    "  \n",
    "  exponentials = jnp.exp(-sq_distances / sig_sq)\n",
    "  \n",
    "  weighted_sum = jnp.sum(v * exponentials)\n",
    "  \n",
    "  return -jnp.log(weighted_sum + 1e-9)\n",
    "\n",
    "\n",
    "def gmm_sampler(\n",
    "    rng: jnp.ndarray, \n",
    "    x_ref: jnp.ndarray, \n",
    "    means: jnp.ndarray, \n",
    "    sampling_theta: jnp.ndarray, \n",
    "    sig_sq: float,\n",
    "):\n",
    "  \"\"\"\n",
    "  Generalised version of `gmm_sampler` from: https://github.com/google-deepmind/implicit_diffusion\n",
    "  \"\"\"\n",
    "  probas = jax.nn.softmax(sampling_theta)\n",
    "  bs = x_ref.shape[0]\n",
    "  num_components = means.shape[0]\n",
    "  \n",
    "  rngs = jax.random.split(rng, 2)\n",
    "\n",
    "  idxs = jax.random.choice(rngs[0], num_components, shape=(bs,), p=probas)\n",
    "  \n",
    "  std_dev = jnp.sqrt(sig_sq) # Use std dev not variance (std_dev ** 2)\n",
    "  \n",
    "  return means[idxs] + std_dev * jax.random.normal(\n",
    "      rngs[1], shape=means[idxs].shape\n",
    "  )\n",
    "\n",
    "\n",
    "def reward_hard(x: jnp.ndarray, center_reward: jnp.ndarray):\n",
    "  \"\"\"An example of a reward function over indivual points.\"\"\"\n",
    "  tau = 20\n",
    "  alpha = 2.5\n",
    "  return (\n",
    "      (x[0] >= 0).astype(float)\n",
    "      * jnp.exp(\n",
    "          -((x[0] - center_reward[0]) ** 2) / tau\n",
    "          - (x[1] - center_reward[1]) ** 2 / tau\n",
    "      )\n",
    "      / alpha\n",
    "  )\n",
    "\n",
    "\n",
    "def reward_smooth(x: jnp.ndarray, center_reward: jnp.ndarray):\n",
    "  \"\"\"An example of a reward function over indivual points - smoothed version.\"\"\"\n",
    "  tau = 20\n",
    "  lamb_reg = 0.5\n",
    "  alpha = 0.7\n",
    "  return (\n",
    "      jax.nn.sigmoid(x[0] / lamb_reg)\n",
    "      * jnp.exp(\n",
    "          -((x[0] - center_reward[0]) ** 2) / tau\n",
    "          - (x[1] - center_reward[1]) ** 2 / tau\n",
    "      )\n",
    "      / alpha\n",
    "  )\n",
    "\n",
    "def reward_multimodal(x: jnp.ndarray, centers: jnp.ndarray):\n",
    "    \"\"\"Multi-modal reward landscape\"\"\"\n",
    "    tau = 15\n",
    "    rewards = jnp.array([jnp.exp(-jnp.sum((x - c)**2) / tau) for c in centers])\n",
    "    return jnp.max(rewards) / 1.5\n",
    "\n",
    "\"\"\"Updates for bilevel Langevin dynamics and parameter optimization.\"\"\"\n",
    "\n",
    "def update_x(rng, x, theta, gamma, grad_v_x):\n",
    "  \"\"\"\n",
    "  Standard Langevin update. \n",
    "  `gamma` is passed as a runtime argument.\n",
    "  \"\"\"\n",
    "  z = jax.random.normal(rng, x.shape)\n",
    "  x = x - gamma * grad_v_x(x, theta) + jnp.sqrt(2 * gamma) * z\n",
    "  return x\n",
    "\n",
    "\n",
    "def update_ref_wrapper(rng, x_ref, sampler_fn: Callable):\n",
    "  \"\"\"A generic wrapper that calls a provided sampler function.\"\"\"\n",
    "  return sampler_fn(rng, x_ref)\n",
    "\n",
    "\n",
    "def update_theta(x, theta, x_ref, eta, lamb_kl, batch_size, grad_v_theta, batch_reward):\n",
    "  \"\"\"Standard (biased) theta update. Used by optim_loop.\"\"\"\n",
    "  mean_x = jnp.mean(grad_v_theta(x, theta), axis=0)\n",
    "  mean_ref = jnp.mean(grad_v_theta(x_ref, theta), axis=0)\n",
    "  update_reward = -batch_reward(x) @ grad_v_theta(\n",
    "      x, theta\n",
    "  ) / batch_size + jnp.mean(batch_reward(x)) * mean_x\n",
    "  update_kl = mean_ref - mean_x\n",
    "  theta = theta + eta * (update_reward + lamb_kl * update_kl)\n",
    "  return theta, update_kl\n",
    "\n",
    "\n",
    "def eta_func_sqrt(eta, t):\n",
    "  return eta / jnp.sqrt(t + 1)\n",
    "\n",
    "\n",
    "def eta_func_const(eta, t):\n",
    "  return eta + 0 * t"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9dc12cbf",
   "metadata": {},
   "source": [
    "# Optimised $\\mathrm{ImpDiff}$ Implementation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "253111a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "class StandardLoopState(NamedTuple):\n",
    "    \"\"\"\n",
    "    Holds recurrent state variables for Standard scan loop.\n",
    "    \"\"\"\n",
    "    rng: jnp.ndarray\n",
    "    x: jnp.ndarray\n",
    "    x_ref: jnp.ndarray\n",
    "    theta: jnp.ndarray\n",
    "    opt_state: Any\n",
    "    t: int\n",
    "\n",
    "\n",
    "class StandardLoopOutputs(NamedTuple):\n",
    "    \"\"\"\n",
    "    Holds history (i.e. per-step outputs) we wish to log.\n",
    "    \"\"\"\n",
    "    reward: float\n",
    "    kl_norm: float\n",
    "    nll: float\n",
    "    theta: jnp.ndarray\n",
    "    x: jnp.ndarray\n",
    "\n",
    "\n",
    "@functools.partial(jax.jit, static_argnames=(\"batch_reward_fn\", \"grad_v_theta_fn\"))\n",
    "def _compute_standard_grad(\n",
    "    x: jnp.ndarray,\n",
    "    theta: jnp.ndarray,\n",
    "    x_ref: jnp.ndarray,\n",
    "    batch_reward_fn: Callable,\n",
    "    grad_v_theta_fn: Callable,\n",
    "    lamb_kl: float,\n",
    "):\n",
    "    \"\"\"\n",
    "    Computes (unweighted) gradient estimate.\n",
    "    \"\"\"\n",
    "    r = batch_reward_fn(x)\n",
    "    g = grad_v_theta_fn(x, theta)\n",
    "\n",
    "    B = x.shape[0]\n",
    "    mean_r = jnp.mean(r)\n",
    "    mean_g = jnp.mean(g, axis=0)\n",
    "\n",
    "    grad_reward = -(r @ g) / B + mean_r * mean_g\n",
    "\n",
    "    mean_ref = jnp.mean(grad_v_theta_fn(x_ref, theta), axis=0)\n",
    "    grad_kl = mean_ref - mean_g\n",
    "\n",
    "    total_ascent = grad_reward + lamb_kl * grad_kl\n",
    "    \n",
    "    return -total_ascent, jnp.linalg.norm(grad_kl)\n",
    "\n",
    "\n",
    "def optim_loop_scan(\n",
    "    rng_seed: int,\n",
    "    gamma: float,\n",
    "    lamb_kl: float,\n",
    "    batch_size: int,\n",
    "    batch_size_ref: int,\n",
    "    dim_x: int,\n",
    "    run_mode: str,\n",
    "    max_steps: int,\n",
    "    max_time_seconds: float,\n",
    "    print_option: bool,\n",
    "    print_every: int,\n",
    "    theta_init: Any,\n",
    "    energy_func: Callable[[Any, Any], Any],\n",
    "    reward_func: Callable[[Any, Any], Any],\n",
    "    reference_sampler_func: Callable[[Any, Any], Any],\n",
    "    optimiser_name: str = 'sgd',\n",
    "    optimiser_kwargs: dict = {'learning_rate': 0.1},\n",
    "    utilise_warmup_step: bool = False,\n",
    ") -> Any:\n",
    "    \"\"\"\n",
    "    Implicit Diffusion loop where:\n",
    "      - X updated via ULA with fixed gamma\n",
    "      - X_{ref} refreshed from reference sampler\n",
    "\n",
    "    Notes\n",
    "    -----\n",
    "    run_mode determines \"mode\" of computation budget:\n",
    "      - \"steps\": use jax.lax.scan for m`ax_steps`\n",
    "      - \"time\":  call a JIT-ted step function in Python until `max_time_seconds`\n",
    "    \"\"\"\n",
    "    grad_v_x = jax.vmap(jax.grad(energy_func, argnums=0), in_axes=(0, None))\n",
    "    grad_v_theta = jax.vmap(jax.grad(energy_func, argnums=1), in_axes=(0, None))\n",
    "\n",
    "    batch_reward = jax.jit(jax.vmap(reward_func))\n",
    "\n",
    "    batch_energy = jax.jit(jax.vmap(lambda x, th: energy_func(x, th), in_axes=(0, None)))\n",
    "\n",
    "    update_x_fn = jax.jit(functools.partial(update_x, gamma=gamma, grad_v_x=grad_v_x))\n",
    "\n",
    "    update_ref_fn = jax.jit(functools.partial(update_ref_wrapper, sampler_fn=reference_sampler_func))\n",
    "\n",
    "    optimizer = build_optimiser(\n",
    "        optimiser_name=optimiser_name,\n",
    "        optimiser_kwargs=optimiser_kwargs,\n",
    "    )\n",
    "\n",
    "    compute_grad_fn = functools.partial(\n",
    "        _compute_standard_grad,\n",
    "        batch_reward_fn=batch_reward,\n",
    "        grad_v_theta_fn=grad_v_theta,\n",
    "        lamb_kl=lamb_kl,\n",
    "    )\n",
    "\n",
    "    @jax.jit\n",
    "    def standard_step(state: StandardLoopState, _):\n",
    "        \"\"\"\n",
    "        Performs one outer iteration.\n",
    "        \"\"\"\n",
    "        rng, x, x_ref, theta, opt_state, t = state\n",
    "\n",
    "        rng, x_key, ref_key = jax.random.split(rng, 3)\n",
    "\n",
    "        x_new = update_x_fn(x_key, x, theta)\n",
    "\n",
    "        x_ref_new = update_ref_fn(ref_key, x_ref)\n",
    "\n",
    "        grad_minimize, kl_norm = compute_grad_fn(x_new, theta, x_ref_new)\n",
    "        updates, opt_state_new = optimizer.update(grad_minimize, opt_state, theta)\n",
    "        theta_new = optax.apply_updates(theta, updates)\n",
    "\n",
    "        nll = -jnp.mean(batch_energy(x_new, theta_new))\n",
    "\n",
    "        # Logging\n",
    "        current_reward = jnp.mean(batch_reward(x_new))\n",
    "\n",
    "        next_state = StandardLoopState(\n",
    "            rng=rng,\n",
    "            x=x_new,\n",
    "            x_ref=x_ref_new,\n",
    "            theta=theta_new,\n",
    "            opt_state=opt_state_new,\n",
    "            t=t + 1,\n",
    "        )\n",
    "\n",
    "        outputs = StandardLoopOutputs(\n",
    "            reward=current_reward,\n",
    "            kl_norm=kl_norm,\n",
    "            nll=nll,\n",
    "            theta=theta,\n",
    "            x=x_new,\n",
    "        )\n",
    "        return next_state, outputs\n",
    "\n",
    "    rng = jax.random.PRNGKey(rng_seed)\n",
    "    rng, x_key, ref_key = jax.random.split(rng, 3)\n",
    "\n",
    "    x_init = jax.random.normal(x_key, (batch_size, dim_x))\n",
    "    x_ref_init = jax.random.normal(ref_key, (batch_size_ref, dim_x))\n",
    "\n",
    "    opt_state_init = optimizer.init(theta_init)\n",
    "\n",
    "    initial_state = StandardLoopState(\n",
    "        rng=rng,\n",
    "        x=x_init,\n",
    "        x_ref=x_ref_init,\n",
    "        theta=theta_init,\n",
    "        opt_state=opt_state_init,\n",
    "        t=0,\n",
    "    )\n",
    "\n",
    "    # Warmup i.e. compile once\n",
    "    if utilise_warmup_step:\n",
    "        print(f\"Warming up JIT for Standard loop (optimiser={optimiser_name})...\")\n",
    "        st_tmp, out_tmp = standard_step(initial_state, None)\n",
    "        jax.block_until_ready(out_tmp.reward)\n",
    "        print(\"Warm-up complete.\")\n",
    "\n",
    "    # Run loop\n",
    "    if run_mode == \"steps\":\n",
    "        print(f\"Running Standard (scan) for {max_steps} steps (optimiser={optimiser_name})...\")\n",
    "        start_time = time.monotonic()\n",
    "\n",
    "        final_state, history = jax.lax.scan(standard_step, initial_state, None, length=max_steps)\n",
    "        jax.block_until_ready(history.reward)\n",
    "\n",
    "        elapsed_time = time.monotonic() - start_time\n",
    "        print(f\"Scan completed in {elapsed_time:.2f} seconds.\")\n",
    "\n",
    "        results_dict = {\n",
    "            \"reward\": np.array(history.reward),\n",
    "            \"kl\": np.array(history.kl_norm),\n",
    "            \"nll\": np.array(history.nll),\n",
    "            \"theta\": np.array(history.theta),\n",
    "            \"x\": np.array(history.x),\n",
    "            \"gamma\": np.full(len(history.reward), gamma),\n",
    "            \"ess\": np.full(len(history.reward), batch_size),   # Just for consistency\n",
    "        }\n",
    "        return results_dict\n",
    "\n",
    "    elif run_mode == \"time\":\n",
    "        print(f\"Running Standard (JIT-step) for {max_time_seconds} seconds (optimiser={optimiser_name})...\")\n",
    "\n",
    "        state = initial_state\n",
    "\n",
    "        hist_reward = []\n",
    "        hist_kl = []\n",
    "        hist_nll = []\n",
    "        hist_theta = []\n",
    "        hist_x = []\n",
    "        hist_time = []\n",
    "\n",
    "        start_time = time.monotonic()\n",
    "        while True:\n",
    "            state, outputs = standard_step(state, None)\n",
    "            jax.block_until_ready(outputs.reward)\n",
    "\n",
    "            elapsed_time = time.monotonic() - start_time\n",
    "            if elapsed_time >= max_time_seconds:\n",
    "                break\n",
    "\n",
    "            hist_reward.append(outputs.reward)\n",
    "            hist_kl.append(outputs.kl_norm)\n",
    "            hist_nll.append(outputs.nll)\n",
    "            hist_theta.append(outputs.theta)\n",
    "            hist_x.append(outputs.x)\n",
    "            hist_time.append(elapsed_time)\n",
    "\n",
    "            if print_option and state.t % print_every == 0:\n",
    "                print(\n",
    "                    f\"step {state.t} (elapsed {elapsed_time:.1f}s / {max_time_seconds}s) \"\n",
    "                    f\"+++ reward = {outputs.reward:.3f} \"\n",
    "                    f\"+++ KL norm = {outputs.kl_norm:.3f} \"\n",
    "                )\n",
    "\n",
    "        results_dict = {\n",
    "            \"reward\": np.array(jnp.array(hist_reward)),\n",
    "            \"kl\": np.array(jnp.array(hist_kl)),\n",
    "            \"nll\": np.array(jnp.array(hist_nll)),\n",
    "            \"theta\": np.array(jnp.array(hist_theta)),\n",
    "            \"x\": np.array(jnp.array(hist_x)),\n",
    "            \"gamma\": np.full(len(hist_reward), gamma),\n",
    "            \"ess\": np.full(len(hist_reward), batch_size),\n",
    "            \"time\": np.array(hist_time),\n",
    "        }\n",
    "        return results_dict\n",
    "\n",
    "    else:\n",
    "        raise ValueError(f\"Unknown run_mode: {run_mode}. Use 'steps' or 'time'.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d52688c",
   "metadata": {},
   "source": [
    "# $\\mathrm{SOSMC}$-$\\mathrm{ULA}$ Implementation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7772087f",
   "metadata": {},
   "outputs": [],
   "source": [
    "@functools.partial(jax.jit, static_argnames=('batch_reward_fn', 'grad_v_theta_fn'))\n",
    "def _compute_sosmc_grad(\n",
    "    x: jnp.ndarray,\n",
    "    theta: jnp.ndarray,\n",
    "    x_ref: jnp.ndarray,\n",
    "    weights: jnp.ndarray,\n",
    "    batch_reward_fn: Callable,\n",
    "    grad_v_theta_fn: Callable,\n",
    "    lamb_kl: float,\n",
    "):\n",
    "    \"\"\"\n",
    "    Computes (weighted) gradient estimate.\n",
    "    \"\"\"\n",
    "    rewards = batch_reward_fn(x)\n",
    "    grad_theta = grad_v_theta_fn(x, theta)\n",
    "\n",
    "    mean_r = jnp.sum(weights * rewards)\n",
    "    mean_g = jnp.sum(weights[:, None] * grad_theta, axis=0)\n",
    "\n",
    "    grad_reward = -jnp.sum((weights * rewards)[:, None] * grad_theta, axis=0) + mean_r * mean_g\n",
    "\n",
    "    mean_ref = jnp.mean(grad_v_theta_fn(x_ref, theta), axis=0)\n",
    "    grad_kl = mean_ref - mean_g\n",
    "\n",
    "    total_ascent = grad_reward + lamb_kl * grad_kl\n",
    "\n",
    "    return -total_ascent, jnp.linalg.norm(grad_kl)\n",
    "\n",
    "\n",
    "def batch_alpha_from_U_grad(\n",
    "    x_left: jnp.ndarray,\n",
    "    x_right: jnp.ndarray,\n",
    "    U_left: jnp.ndarray,\n",
    "    gradU_left: jnp.ndarray,\n",
    "    h: float,\n",
    ") -> jnp.ndarray:\n",
    "    \"\"\"\n",
    "    Alpha term. (No auto differentiation used here.)\n",
    "    \"\"\"\n",
    "    dx = x_right - x_left\n",
    "    term2 = 0.5 * jnp.sum(dx * gradU_left, axis=1)\n",
    "    term3 = (h / 4.0) * jnp.sum(gradU_left * gradU_left, axis=1)\n",
    "\n",
    "    return U_left + term2 + term3\n",
    "\n",
    "\n",
    "class SOSMCLoopState(NamedTuple):\n",
    "    rng: jnp.ndarray\n",
    "    x: jnp.ndarray\n",
    "    x_ref: jnp.ndarray\n",
    "    theta: jnp.ndarray\n",
    "    log_A: jnp.ndarray\n",
    "    gamma: float\n",
    "    opt_state: Any\n",
    "    t: int\n",
    "\n",
    "\n",
    "class SOSMCLoopOutputs(NamedTuple):\n",
    "    reward: float\n",
    "    kl_norm: float\n",
    "    nll: float\n",
    "    theta: jnp.ndarray\n",
    "    x: jnp.ndarray\n",
    "    gamma: float\n",
    "    ess: float\n",
    "\n",
    "\n",
    "def sosmc_optim_loop_adaptive_optimised(\n",
    "    rng_seed: int,\n",
    "    gamma_init: float,\n",
    "    lamb_kl: float,\n",
    "    batch_size: int,\n",
    "    batch_size_ref: int,\n",
    "    dim_x: int,\n",
    "    run_mode: str,\n",
    "    max_steps: int,\n",
    "    max_time_seconds: float,\n",
    "    print_option: bool,\n",
    "    print_every: int,\n",
    "    theta_init: Any,\n",
    "    energy_func: Callable,\n",
    "    reward_func: Callable,\n",
    "    reference_sampler_func: Callable[[Any, Any], Any],\n",
    "    ess_resample_ratio: float = 0.9,\n",
    "    ess_adapt_ratio: float = 0.95,\n",
    "    gamma_min: float = 0.001,\n",
    "    gamma_max: float = 0.99,\n",
    "    adapt_factor: float = 1.0,\n",
    "    utilise_warmup_step: bool = False,\n",
    "    optimiser_name: str = 'sgd',\n",
    "    optimiser_kwargs: dict = {'learning_rate': 0.1},\n",
    "):\n",
    "    \"\"\"\n",
    "    SOSMC-ULA implementation with:\n",
    "      - exactly 2 batch (value, \\\\nabla_x) evaluations of energy_func per outer step.\n",
    "      - Weighted theta-gradient update\n",
    "      - ESS-based resampling and gamma adaptation\n",
    "    \"\"\"\n",
    "    batch_reward = jax.jit(jax.vmap(reward_func))\n",
    "\n",
    "    grad_v_theta = jax.vmap(jax.grad(energy_func, argnums=1), in_axes=(0, None))\n",
    "\n",
    "    batch_U_and_gradx = jax.jit(\n",
    "        jax.vmap(jax.value_and_grad(energy_func, argnums=0), in_axes=(0, None))\n",
    "    )\n",
    "\n",
    "    # Reference sampler wrapper\n",
    "    @jax.jit\n",
    "    def update_ref_fn(rng, x_ref):\n",
    "        return reference_sampler_func(rng, x_ref)\n",
    "\n",
    "    # COmputes theta gradient (weighted)\n",
    "    compute_grad_fn = functools.partial(\n",
    "        _compute_sosmc_grad,\n",
    "        batch_reward_fn=batch_reward,\n",
    "        grad_v_theta_fn=grad_v_theta,\n",
    "        lamb_kl=lamb_kl,\n",
    "    )\n",
    "\n",
    "    optimizer = build_optimiser(\n",
    "        optimiser_name=optimiser_name,\n",
    "        optimiser_kwargs=optimiser_kwargs,\n",
    "    )\n",
    "\n",
    "    @jax.jit\n",
    "    def sosmc_step(state: SOSMCLoopState, _):\n",
    "        rng, x, x_ref, theta, log_A, gamma, opt_state, t = state\n",
    "\n",
    "        weights = jax.nn.softmax(log_A)\n",
    "        grad_minimize, kl_norm = compute_grad_fn(x, theta, x_ref, weights)\n",
    "\n",
    "        updates, opt_state_new = optimizer.update(grad_minimize, opt_state, theta)\n",
    "        theta_new = optax.apply_updates(theta, updates)\n",
    "\n",
    "        rng, z_key, ref_key, resample_key = jax.random.split(rng, 4)\n",
    "\n",
    "        U_x, gradU_x = batch_U_and_gradx(x, theta)\n",
    "\n",
    "        # ULA step reusing \\nabla U_x\n",
    "        z = jax.random.normal(z_key, x.shape)\n",
    "        x_new = x - gamma * gradU_x + jnp.sqrt(2.0 * gamma) * z\n",
    "\n",
    "        # Refresh reference batch\n",
    "        x_ref_new = update_ref_fn(ref_key, x_ref)\n",
    "\n",
    "        U_xnew, gradU_xnew = batch_U_and_gradx(x_new, theta_new)\n",
    "\n",
    "        alpha_k = batch_alpha_from_U_grad(x, x_new, U_x, gradU_x, gamma)\n",
    "        alpha_k_plus_1 = batch_alpha_from_U_grad(x_new, x, U_xnew, gradU_xnew, gamma)\n",
    "\n",
    "        log_A_new = log_A - alpha_k_plus_1 + alpha_k\n",
    "\n",
    "        # ESS resampling\n",
    "        weights_new = jax.nn.softmax(log_A_new)\n",
    "        ess = 1.0 / jnp.sum(weights_new * weights_new)\n",
    "\n",
    "        nll = -jnp.mean(U_xnew)\n",
    "\n",
    "        ess_resample_threshold = ess_resample_ratio * batch_size\n",
    "\n",
    "        def resample_fn():\n",
    "            idx = jax.random.choice(\n",
    "                resample_key,\n",
    "                a=batch_size,\n",
    "                shape=(batch_size,),\n",
    "                p=weights_new,\n",
    "            )\n",
    "            return x_new[idx], jnp.zeros(batch_size)\n",
    "\n",
    "        def no_resample_fn():\n",
    "            return x_new, log_A_new\n",
    "\n",
    "        x_final, log_A_final = jax.lax.cond(\n",
    "            ess < ess_resample_threshold,\n",
    "            resample_fn,\n",
    "            no_resample_fn,\n",
    "        )\n",
    "\n",
    "        # Gamma adaptation\n",
    "        ess_adapt_threshold = ess_adapt_ratio * batch_size\n",
    "\n",
    "        gamma_new = jax.lax.cond(\n",
    "            ess < ess_adapt_threshold,\n",
    "            lambda: jnp.maximum(gamma / adapt_factor, gamma_min),\n",
    "            lambda: jnp.minimum(gamma * adapt_factor, gamma_max),\n",
    "        )\n",
    "\n",
    "        # Logging\n",
    "        current_reward = jnp.mean(batch_reward(x_final))\n",
    "\n",
    "        next_state = SOSMCLoopState(\n",
    "            rng=rng,\n",
    "            x=x_final,\n",
    "            x_ref=x_ref_new,\n",
    "            theta=theta_new,\n",
    "            log_A=log_A_final,\n",
    "            gamma=gamma_new,\n",
    "            opt_state=opt_state_new,\n",
    "            t=t + 1,\n",
    "        )\n",
    "\n",
    "        outputs = SOSMCLoopOutputs(\n",
    "            reward=current_reward,\n",
    "            kl_norm=kl_norm,\n",
    "            nll=nll,\n",
    "            theta=theta,\n",
    "            x=x_final,\n",
    "            gamma=gamma,\n",
    "            ess=ess,\n",
    "        )\n",
    "\n",
    "        return next_state, outputs\n",
    "\n",
    "    rng = jax.random.PRNGKey(rng_seed)\n",
    "    rng, x_key, ref_key = jax.random.split(rng, 3)\n",
    "\n",
    "    x_init = jax.random.normal(x_key, (batch_size, dim_x))\n",
    "    x_ref_init = jax.random.normal(ref_key, (batch_size_ref, dim_x))\n",
    "\n",
    "    log_A_init = jnp.zeros((batch_size,))\n",
    "    opt_state_init = optimizer.init(theta_init)\n",
    "\n",
    "    initial_state = SOSMCLoopState(\n",
    "        rng=rng,\n",
    "        x=x_init,\n",
    "        x_ref=x_ref_init,\n",
    "        theta=theta_init,\n",
    "        log_A=log_A_init,\n",
    "        gamma=gamma_init,\n",
    "        opt_state=opt_state_init,\n",
    "        t=0,\n",
    "    )\n",
    "\n",
    "    # Warmup i,.e compile once\n",
    "    if utilise_warmup_step:\n",
    "        st_tmp, out_tmp = sosmc_step(initial_state, None)\n",
    "        jax.block_until_ready(out_tmp.reward)\n",
    "\n",
    "    # Run loop\n",
    "    if run_mode == \"steps\":\n",
    "        print(f\"Running SOSMC (scan) for {max_steps} steps...\")\n",
    "        start = time.monotonic()\n",
    "\n",
    "        final_state, history = jax.lax.scan(sosmc_step, initial_state, None, length=max_steps)\n",
    "        jax.block_until_ready(history.reward)\n",
    "\n",
    "        elapsed = time.monotonic() - start\n",
    "        print(f\"Scan completed in {elapsed:.2f} seconds.\")\n",
    "\n",
    "        return {\n",
    "            \"reward\": np.array(history.reward),\n",
    "            \"kl\": np.array(history.kl_norm),\n",
    "            \"nll\": np.array(history.nll),\n",
    "            \"theta\": np.array(history.theta),\n",
    "            \"x\": np.array(history.x),\n",
    "            \"gamma\": np.array(history.gamma),\n",
    "            \"ess\": np.array(history.ess),\n",
    "        }\n",
    "\n",
    "    elif run_mode == \"time\":\n",
    "        print(f\"Running SOSMC (JIT-step) for {max_time_seconds} seconds...\")\n",
    "\n",
    "        state = initial_state\n",
    "\n",
    "        hist_reward, hist_kl, hist_nll, hist_theta, hist_x, hist_gamma, hist_ess, hist_time = ([] for _ in range(8))\n",
    "\n",
    "        start = time.monotonic()\n",
    "        while True:\n",
    "            state, out = sosmc_step(state, None)\n",
    "            jax.block_until_ready(out.reward)\n",
    "\n",
    "            elapsed = time.monotonic() - start\n",
    "            if elapsed >= max_time_seconds:\n",
    "                break\n",
    "\n",
    "            hist_reward.append(out.reward)\n",
    "            hist_kl.append(out.kl_norm)\n",
    "            hist_nll.append(out.nll)\n",
    "            hist_theta.append(out.theta)\n",
    "            hist_x.append(out.x)\n",
    "            hist_gamma.append(out.gamma)\n",
    "            hist_ess.append(out.ess)\n",
    "            hist_time.append(elapsed)\n",
    "\n",
    "            if print_option and state.t % print_every == 0:\n",
    "                print(\n",
    "                    f\"step {state.t} (elapsed {elapsed:.1f}s / {max_time_seconds}s) \"\n",
    "                    f\"+++ reward = {out.reward:.3f} \"\n",
    "                    f\"+++ KL norm = {out.kl_norm:.3f} \"\n",
    "                    f\"+++ ESS = {out.ess:.1f} \"\n",
    "                    f\"+++ gamma = {float(out.gamma):.4f}\"\n",
    "                )\n",
    "\n",
    "        return {\n",
    "            \"reward\": np.array(jnp.array(hist_reward)),\n",
    "            \"kl\": np.array(jnp.array(hist_kl)),\n",
    "            \"nll\": np.array(jnp.array(hist_nll)),\n",
    "            \"theta\": np.array(jnp.array(hist_theta)),\n",
    "            \"x\": np.array(jnp.array(hist_x)),\n",
    "            \"gamma\": np.array(jnp.array(hist_gamma)),\n",
    "            \"ess\": np.array(jnp.array(hist_ess)),\n",
    "            \"time\": np.array(hist_time),\n",
    "        }\n",
    "\n",
    "    else:\n",
    "        raise ValueError(f\"Unknown run_mode: {run_mode}. Use 'steps' or 'time'.\")\n",
    "    \n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4ced57b3",
   "metadata": {},
   "source": [
    "# Optimised $\\mathrm{SOUL}$ Implementation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0e8ee0a6",
   "metadata": {},
   "outputs": [],
   "source": [
    "@functools.partial(jax.jit, static_argnames=(\"batch_reward_fn\", \"grad_v_theta_fn\"))\n",
    "def _compute_soul_grad(\n",
    "    x_samples: jnp.ndarray,\n",
    "    theta: jnp.ndarray,\n",
    "    x_ref: jnp.ndarray,\n",
    "    batch_reward_fn: Callable,\n",
    "    grad_v_theta_fn: Callable,\n",
    "    lamb_kl: float,\n",
    "):\n",
    "    \"\"\"\n",
    "    Computes (unweighted) gradient estimate.\n",
    "    \"\"\"\n",
    "    r = batch_reward_fn(x_samples)\n",
    "    g = grad_v_theta_fn(x_samples, theta)\n",
    "\n",
    "    mean_r = jnp.mean(r)\n",
    "    mean_g = jnp.mean(g, axis=0)\n",
    "\n",
    "    n_eff = x_samples.shape[0]\n",
    "    grad_reward = -(r @ g) / n_eff + mean_r * mean_g\n",
    "\n",
    "    mean_ref = jnp.mean(grad_v_theta_fn(x_ref, theta), axis=0)\n",
    "    grad_kl = mean_ref - mean_g\n",
    "\n",
    "    total_ascent = grad_reward + lamb_kl * grad_kl\n",
    "\n",
    "    return -total_ascent, jnp.linalg.norm(grad_kl)\n",
    "\n",
    "\n",
    "class SoulLoopState(NamedTuple):\n",
    "    rng: jnp.ndarray\n",
    "    x_chain: jnp.ndarray\n",
    "    x_ref: jnp.ndarray\n",
    "    theta: jnp.ndarray\n",
    "    opt_state: Any\n",
    "    t: int\n",
    "\n",
    "\n",
    "class SoulLoopOutputs(NamedTuple):\n",
    "    reward: float\n",
    "    kl_norm: float\n",
    "    nll: float\n",
    "    theta: jnp.ndarray\n",
    "    x: jnp.ndarray\n",
    "    gamma: float\n",
    "    ess: float\n",
    "\n",
    "\n",
    "def soul_optim_loop_adaptive_optimised(\n",
    "    rng_seed: int,\n",
    "    gamma: float,\n",
    "    lamb_kl: float,\n",
    "    batch_size: int,              # unused for SOUL (kept for consistency)\n",
    "    batch_size_ref: int,\n",
    "    dim_x: int,\n",
    "    run_mode: str,\n",
    "    max_steps: int,\n",
    "    max_time_seconds: float,\n",
    "    print_option: bool,\n",
    "    print_every: int,\n",
    "    theta_init: Any,\n",
    "    energy_func: Callable[[Any, Any], Any],\n",
    "    reward_func: Callable[[Any], Any],\n",
    "    reference_sampler_func: Callable[[Any, Any], Any],\n",
    "    N: int = 50,                  # inner ULA steps per outer step\n",
    "    n_burn: int = 0,              # burn-in inside the N inner steps; use N-n_burn samples\n",
    "    optimiser_name: str = \"sgd\",  # \"sgd\" or \"adam\"\n",
    "    optimiser_kwargs: dict = {'learning_rate': 0.1},\n",
    "    utilise_warmup_step: bool = False,\n",
    ") -> Any:\n",
    "    \"\"\"\n",
    "    SOUL, where per outer iteration we:\n",
    "    - Run single ULA chain for N steps at theta_k, warm-started from previous x_chain.\n",
    "    - Discard first n_burn samples -> use remaining N_eff = N - n_burn samples for theta gradient.\n",
    "    - Refresh x_ref via `reference_sampler_func` (like before).\n",
    "    \"\"\"\n",
    "    if n_burn < 0 or n_burn >= N:\n",
    "        raise ValueError(f\"n_burn must satisfy 0 <= n_burn < N. Got n_burn={n_burn}, N={N}\")\n",
    "    \n",
    "    N_eff = N - n_burn\n",
    "\n",
    "    grad_v_x_single = jax.grad(energy_func, argnums=0)\n",
    "    grad_v_theta = jax.vmap(jax.grad(energy_func, argnums=1), in_axes=(0, None))\n",
    "\n",
    "    batch_reward = jax.jit(jax.vmap(reward_func))\n",
    "\n",
    "    batch_energy = jax.jit(jax.vmap(lambda x, th: energy_func(x, th), in_axes=(0, None)))\n",
    "\n",
    "    update_ref_fn = jax.jit(functools.partial(update_ref_wrapper, sampler_fn=reference_sampler_func))\n",
    "\n",
    "    compute_grad_fn = functools.partial(\n",
    "        _compute_soul_grad,\n",
    "        batch_reward_fn=batch_reward,\n",
    "        grad_v_theta_fn=grad_v_theta,\n",
    "        lamb_kl=lamb_kl,\n",
    "    )\n",
    "\n",
    "    optimizer = build_optimiser(\n",
    "        optimiser_name=optimiser_name,\n",
    "        optimiser_kwargs=optimiser_kwargs,\n",
    "    )\n",
    "\n",
    "    # Runs ULA chain for N steps.\n",
    "    @jax.jit\n",
    "    def run_chain_N(rng, x0, theta):\n",
    "        keys = jax.random.split(rng, N)\n",
    "\n",
    "        def inner(x, key):\n",
    "            noise = jax.random.normal(key, x.shape)\n",
    "            x_next = x - gamma * grad_v_x_single(x, theta) + jnp.sqrt(2.0 * gamma) * noise\n",
    "            return x_next, x_next\n",
    "\n",
    "        xN, xs = jax.lax.scan(inner, x0, keys)\n",
    "\n",
    "        return xN, xs\n",
    "\n",
    "    @jax.jit\n",
    "    def soul_step(state: SoulLoopState, _):\n",
    "        rng, x_chain, x_ref, theta, opt_state, t = state\n",
    "\n",
    "        rng, chain_rng, ref_rng = jax.random.split(rng, 3)\n",
    "\n",
    "        x_chain_new, xs = run_chain_N(chain_rng, x_chain, theta)\n",
    "\n",
    "        x_used = xs[n_burn:] # Burn-in\n",
    "\n",
    "        x_ref_new = update_ref_fn(ref_rng, x_ref)\n",
    "\n",
    "        grad_minimize, kl_norm = compute_grad_fn(x_used, theta, x_ref_new)\n",
    "        updates, opt_state_new = optimizer.update(grad_minimize, opt_state, theta)\n",
    "        theta_new = optax.apply_updates(theta, updates)\n",
    "\n",
    "        nll_now = -jnp.mean(batch_energy(x_used, theta_new))\n",
    "\n",
    "        # Logging\n",
    "        reward_now = jnp.mean(batch_reward(x_used))\n",
    "\n",
    "        next_state = SoulLoopState(\n",
    "            rng=rng,\n",
    "            x_chain=x_chain_new,\n",
    "            x_ref=x_ref_new,\n",
    "            theta=theta_new,\n",
    "            opt_state=opt_state_new,\n",
    "            t=t + 1,\n",
    "        )\n",
    "\n",
    "        outputs = SoulLoopOutputs(\n",
    "            reward=reward_now,\n",
    "            kl_norm=kl_norm,\n",
    "            nll=nll_now,\n",
    "            theta=theta,\n",
    "            x=x_used,\n",
    "            gamma=jnp.asarray(gamma),\n",
    "            ess=jnp.asarray(N_eff, dtype=jnp.float32),\n",
    "        )\n",
    "        return next_state, outputs\n",
    "\n",
    "    rng = jax.random.PRNGKey(rng_seed)\n",
    "    rng, x_key, ref_key = jax.random.split(rng, 3)\n",
    "\n",
    "    x_chain_init = jax.random.normal(x_key, (dim_x,))\n",
    "    x_ref_init = jax.random.normal(ref_key, (batch_size_ref, dim_x))\n",
    "\n",
    "    opt_state_init = optimizer.init(theta_init)\n",
    "\n",
    "    init_state = SoulLoopState(\n",
    "        rng=rng,\n",
    "        x_chain=x_chain_init,\n",
    "        x_ref=x_ref_init,\n",
    "        theta=theta_init,\n",
    "        opt_state=opt_state_init,\n",
    "        t=0,\n",
    "    )\n",
    "\n",
    "    # Warmup i.e. compile once\n",
    "    if utilise_warmup_step:\n",
    "        st_tmp, out_tmp = soul_step(init_state, None)\n",
    "        jax.block_until_ready(out_tmp.reward)\n",
    "\n",
    "    # Run loop\n",
    "    if run_mode == \"steps\":\n",
    "        print(f\"Running SOUL (scan) for {max_steps} outer steps with N={N}, n_burn={n_burn}, N_eff={N_eff}...\")\n",
    "        start = time.monotonic()\n",
    "\n",
    "        final_state, history = jax.lax.scan(soul_step, init_state, None, length=max_steps)\n",
    "        jax.block_until_ready(history.reward)\n",
    "\n",
    "        elapsed = time.monotonic() - start\n",
    "        print(f\"Scan completed in {elapsed:.2f} seconds.\")\n",
    "\n",
    "        return {\n",
    "            \"reward\": np.array(history.reward),\n",
    "            \"kl\": np.array(history.kl_norm),\n",
    "            \"nll\": np.array(history.nll),\n",
    "            \"theta\": np.array(history.theta),\n",
    "            \"x\": np.array(history.x),\n",
    "            \"gamma\": np.full((len(history.reward),), float(gamma)),\n",
    "            \"ess\": np.full((len(history.reward),), float(N_eff)),\n",
    "        }\n",
    "\n",
    "    elif run_mode == \"time\":\n",
    "        print(f\"Running SOUL (JIT-step) for {max_time_seconds} seconds with N={N}, n_burn={n_burn}, N_eff={N_eff}...\")\n",
    "        state = init_state\n",
    "\n",
    "        hist_reward, hist_kl, hist_nll, hist_theta, hist_x, hist_gamma, hist_ess, hist_time = ([] for _ in range(8))\n",
    "\n",
    "        start = time.monotonic()\n",
    "        while True:\n",
    "            state, out = soul_step(state, None)\n",
    "            jax.block_until_ready(out.reward)\n",
    "\n",
    "            elapsed = time.monotonic() - start\n",
    "            if elapsed >= max_time_seconds:\n",
    "                break\n",
    "\n",
    "            hist_reward.append(out.reward)\n",
    "            hist_kl.append(out.kl_norm)\n",
    "            hist_nll.append(out.nll)\n",
    "            hist_theta.append(out.theta)\n",
    "            hist_x.append(out.x)\n",
    "            hist_gamma.append(out.gamma)\n",
    "            hist_ess.append(out.ess)\n",
    "            hist_time.append(elapsed)\n",
    "\n",
    "            if print_option and state.t % print_every == 0:\n",
    "                print(\n",
    "                    f\"outer {state.t} (elapsed {elapsed:.1f}s / {max_time_seconds}s) \"\n",
    "                    f\"+++ reward = {out.reward:.3f} \"\n",
    "                    f\"+++ KL norm = {out.kl_norm:.3f} \"\n",
    "                    f\"+++ N_eff = {N_eff} \"\n",
    "                    f\"+++ gamma = {float(gamma):.4f}\"\n",
    "                )\n",
    "\n",
    "        return {\n",
    "            \"reward\": np.array(jnp.array(hist_reward)),\n",
    "            \"kl\": np.array(jnp.array(hist_kl)),\n",
    "            \"nll\": np.array(jnp.array(hist_nll)),\n",
    "            \"theta\": np.array(jnp.array(hist_theta)),\n",
    "            \"x\": np.array(jnp.array(hist_x)),      # (iters, N_eff, dim_x)\n",
    "            \"gamma\": np.array(jnp.array(hist_gamma)),\n",
    "            \"ess\": np.array(jnp.array(hist_ess)),\n",
    "            \"time\": np.array(hist_time),\n",
    "        }\n",
    "\n",
    "    else:\n",
    "        raise ValueError(f\"Unknown run_mode: {run_mode}. Use 'steps' or 'time'.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08d9a07f",
   "metadata": {},
   "source": [
    "# Representative Experimental Trials"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "94edef50",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running Trial: Dual Gaussian (sig_sq=1.0) + Hard Reward (Right)\n",
      "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n",
      "\n",
      "-----------------------------------\n",
      "Running: ImpDiff_Adam\n",
      "-----------------------------------\n",
      "Warming up JIT for Standard loop (optimiser=adam)...\n",
      "Warm-up complete.\n",
      "Running Standard (JIT-step) for 2.0 seconds (optimiser=adam)...\n",
      "step 1000 (elapsed 1.2s / 2.0s) +++ reward = 0.018 +++ KL norm = 0.000 \n",
      "Completed 1714 iterations\n",
      "Total time: 2.00s\n",
      "Final reward: 0.018\n",
      "Final ESS: 10000.0\n",
      "Final gamma: 0.1000\n",
      "\n",
      "-----------------------------------\n",
      "Running: SOSMC-ULA_Adam\n",
      "-----------------------------------\n",
      "Running SOSMC (JIT-step) for 2.0 seconds...\n",
      "step 1000 (elapsed 1.2s / 2.0s) +++ reward = 0.019 +++ KL norm = 0.001 +++ ESS = 9487.7 +++ gamma = 0.1417\n",
      "Completed 1778 iterations\n",
      "Total time: 2.00s\n",
      "Final reward: 0.019\n",
      "Final ESS: 9488.5\n",
      "Final gamma: 0.1282\n",
      "\n",
      "-----------------------------------\n",
      "Running: SOUL_Adam\n",
      "-----------------------------------\n",
      "Running SOUL (JIT-step) for 2.0 seconds with N=10000, n_burn=5000, N_eff=5000...\n",
      "Completed 829 iterations\n",
      "Total time: 2.00s\n",
      "Final reward: 0.019\n",
      "Final ESS: 5000.0\n",
      "Final gamma: 0.1000\n",
      "\n",
      "... Generating plot for Dual Gaussian (sig_sq=1.0) + Hard Reward (Right) (x-axis: time) ...\n"
     ]
    },
    {
     "data": {
      "image/png": "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H5ZnnnlG/Ani7HGNOCfQp08fNUsXrqNNmzbSr18/+fXXX6t8nM8++0yuvPLKcj+fMGGCnH322dK2bVt1Puedd5589913Ekiefvpp+frrr32+38GDB8vChQvdbnPppZfKxo0bJdj49NNPpVOnTirG+o033nC77d9//63qzSmnnCIXXHCB7N69W63HFKVnnnmmHDt2rEzd/uabb/x+/iRA4N5OmiTx06ZVbT8NG4p8/rksvMzehvp7Wusnej6hXnOLcv17IEIIIV6Hznnq0RRs9kDv3r3ljDPOoD3gAtoDtAeOBbk9wGTg1Qw6AB3SgI6hIN+iRodhFESZOoXiwhgpKChd4Y3RgBkngs1l9uOPP3b8PWPGDCUWLViwQIUP4kei31fExIkTleH9/fffy5tvvqm+V1288847csUVV0hqaqpj3dixYx2iEDrVa6+9Vt577z25+uqr/Vaur776qioPiBQAostPP/0kgeS5557z+T4XL16sHjq6d+/udrvffvtNghHU02+//VbGjBlT4QxvN9xwg3z44YdKJIQoNXLkSJk0aZJK6jd06FB57bXXHGX86KOPKmF20KBBAboS4leOHRPLl19KAhruoUOrvDvdJGZni19pkGyf4mh/7n7VjjPUkhBCKmcP6PfFxfbE3p4+w8NzFftA6idtJ+BV7xvzeISKPaAHTvX7ivoU2gMnlivtgci0B6655hoJFujRVM2g4R882L4MGWKR+29vJPfd1lD9rddjuWNoLbVeL+bPKlq8zc0BT5yHHnpIevXqpaYyHzVqlDLeUXkx0vH66687tsX7Rx55RP1o4LXz3/+W5uf466+/1KjEqaeeKrfeeqvKmG8+xg8//CB//PGH+v6iRYvUtnj/xBNPlHnvjk8++UQee+wxda7oZDSYLvaiiy5SYsuFF14ou3btcnw2c+ZMJVZghKRjx45qH5pbbrlF7rzzTvUdeCPddtttSuDA+bZq1UoefPDBcs9l3Lhxcv3117stV3hV6YbFeSTil19+UduAvXv3yvnnn6/KFed47733qganIrB/NERaZALt2rVTZQxwD1AuGE3CfnG+OTk5DiEMZa5Zu3atur/gwIED0r9/f+WRc9ppp6n7CXCfcI76Pr///vuOctReOxWV91133aW8dk4++WQlwBWWE+PjXL7oRHGdODbOC15AzqNxGzZsUMfGcbFv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",
      "text/plain": [
       "<Figure size 1200x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n",
      "All experiments complete!\n"
     ]
    }
   ],
   "source": [
    "HEX_MEANS = 4.0 * jnp.array([\n",
    "    [1., 0.],\n",
    "    [1/2, jnp.sqrt(3)/2],\n",
    "    [-1/2, jnp.sqrt(3)/2],\n",
    "    [-1., 0.],\n",
    "    [-1/2, -jnp.sqrt(3)/2],\n",
    "    [1/2, -jnp.sqrt(3)/2]\n",
    "])\n",
    "\n",
    "TRUE_THETA_HEX_SPARSE = jnp.array([1.5, -1.5, 1.5, -1.5, 1.5, -1.5])\n",
    "THETA_INIT_HEX_SPARSE = jnp.zeros(6)\n",
    "\n",
    "TRUE_THETA_HEX_UNIFORM = jnp.zeros(6)\n",
    "THETA_INIT_HEX_UNIFORM = jnp.ones(6)\n",
    "\n",
    "DUAL_MEANS = jnp.array([[-3.0, 0.0], [3.0, 0.0]])\n",
    "TRUE_DUAL_THETA = jnp.array([0.0, 0.0])\n",
    "THETA_INIT_DUAL = jnp.array([-1.0, 1.0])\n",
    "\n",
    "CONFIG_DISTRIBUTION = {\n",
    "    'hex_sparse_sig2': {\n",
    "        'name': 'Hex (Sparse, sig_sq=2.0)',\n",
    "        'energy_func': gmm_energy,\n",
    "        'sampler_func': gmm_sampler,\n",
    "        'energy_params': {'sig_sq': 2.0, 'means': HEX_MEANS},\n",
    "        'sampler_params': {'sig_sq': 2.0, 'means': HEX_MEANS, 'sampling_theta': TRUE_THETA_HEX_SPARSE},\n",
    "        'theta_init': THETA_INIT_HEX_SPARSE\n",
    "    },\n",
    "    'hex_uniform_sig10': {\n",
    "        'name': 'Hex (Uniform, sig_sq=10.0)',\n",
    "        'energy_func': gmm_energy,\n",
    "        'sampler_func': gmm_sampler,\n",
    "        'energy_params': {'sig_sq': 10.0, 'means': HEX_MEANS},\n",
    "        'sampler_params': {'sig_sq': 10.0, 'means': HEX_MEANS, 'sampling_theta': TRUE_THETA_HEX_UNIFORM},\n",
    "        'theta_init': THETA_INIT_HEX_UNIFORM\n",
    "    },\n",
    "    'dual_gaussian_sig1': {\n",
    "         'name': 'Dual Gaussian (sig_sq=1.0)',\n",
    "         'energy_func': gmm_energy,\n",
    "         'sampler_func': gmm_sampler,\n",
    "         'energy_params': {'sig_sq': 1.0, 'means': DUAL_MEANS},\n",
    "         'sampler_params': {'sig_sq': 1.0, 'means': DUAL_MEANS, 'sampling_theta': TRUE_DUAL_THETA},\n",
    "         'theta_init': THETA_INIT_DUAL\n",
    "    }\n",
    "}\n",
    "\n",
    "CONFIG_REWARD = {\n",
    "    'hard_right': {\n",
    "        'name': 'Hard Reward (Right)',\n",
    "        'reward_func': reward_hard,\n",
    "        'params': {'center_reward': jnp.array([10.0, 3.8])}\n",
    "    },\n",
    "    'smooth_right': {\n",
    "        'name': 'Smooth Reward (Right)',\n",
    "        'reward_func': reward_smooth,\n",
    "        'params': {'center_reward': jnp.array([4.0, 3.8])}\n",
    "    },\n",
    "}\n",
    "\n",
    "CONFIG_BASE = {\n",
    "    'rng_seed': 42,\n",
    "    'lamb_kl': 0.1,\n",
    "    'batch_size': 10_000,\n",
    "    'batch_size_ref': 5_000,\n",
    "    'dim_x': 2,\n",
    "    'print_every': 1000,\n",
    "    'print_option': True,\n",
    "    'run_mode': 'time',\n",
    "    'max_time_seconds': 3,\n",
    "    'max_steps': None,\n",
    "    'utilise_warmup_step': False,\n",
    "}\n",
    "\n",
    "CONFIG_LOOP = {\n",
    "    # ImpDiff\n",
    "    'ImpDiff_Adam': {\n",
    "        'fn': optim_loop_scan,\n",
    "        'params': {\n",
    "            'gamma': 0.1,\n",
    "            'optimiser_name': 'adam',\n",
    "            'optimiser_kwargs': {'learning_rate': 0.1},\n",
    "        }\n",
    "    },\n",
    "\n",
    "    # SOSMC-ULA\n",
    "    'SOSMC-ULA_Adam': {\n",
    "        'fn': sosmc_optim_loop_adaptive_optimised,\n",
    "        'params': {\n",
    "            'gamma_init': 0.1,\n",
    "            'ess_resample_ratio': 0.9,\n",
    "            'ess_adapt_ratio': 0.95,\n",
    "            'optimiser_name': 'adam',\n",
    "            'optimiser_kwargs': {'learning_rate': 0.1},\n",
    "            'adapt_factor': 1.01,\n",
    "        }\n",
    "    },\n",
    "    # SOUL\n",
    "    'SOUL_Adam': {\n",
    "        'fn': soul_optim_loop_adaptive_optimised,\n",
    "        'params': {\n",
    "            'gamma': 0.1,\n",
    "            'N': CONFIG_BASE['batch_size'],  # inner ULA steps\n",
    "            'n_burn': int(CONFIG_BASE['batch_size'] / 2),\n",
    "            'optimiser_name': 'adam',\n",
    "            'optimiser_kwargs': {'learning_rate': 0.1},\n",
    "        }\n",
    "    },\n",
    "}\n",
    "\n",
    "experiments_to_run = [\n",
    "    ('dual_gaussian_sig1', 'hard_right'),\n",
    "]\n",
    "\n",
    "run_settings = {\n",
    "    'run_mode': 'time',\n",
    "    'max_time_seconds': 2.0,\n",
    "    'max_steps': None,\n",
    "    'utilise_warmup_step': True,\n",
    "}\n",
    "\n",
    "loop_types = [\n",
    "    'ImpDiff_Adam',\n",
    "    'SOSMC-ULA_Adam',\n",
    "    'SOUL_Adam',\n",
    "]\n",
    "\n",
    "all_results = {}\n",
    "\n",
    "for dist_key, reward_key in experiments_to_run:\n",
    "    dist_config = CONFIG_DISTRIBUTION[dist_key]\n",
    "    reward_config = CONFIG_REWARD[reward_key]\n",
    "\n",
    "    experiment_title = f\"{dist_config['name']} + {reward_config['name']}\"\n",
    "    print(f\"Running Trial: {experiment_title}\")\n",
    "    print(\"~\"*65)\n",
    "\n",
    "    energy_fn = functools.partial(dist_config['energy_func'], **dist_config['energy_params'])\n",
    "    reward_fn = functools.partial(reward_config['reward_func'], **reward_config['params'])\n",
    "    sampler_fn = functools.partial(dist_config['sampler_func'], **dist_config['sampler_params'])\n",
    "\n",
    "    results_for_this_plot = {}\n",
    "\n",
    "    for loop_type in loop_types:\n",
    "        loop_cfg = CONFIG_LOOP[loop_type]\n",
    "        loop_fn = loop_cfg['fn']\n",
    "\n",
    "        params = CONFIG_BASE.copy()\n",
    "        params.update(run_settings)\n",
    "\n",
    "        params.update({\n",
    "            'theta_init': dist_config['theta_init'],\n",
    "            'energy_func': energy_fn,\n",
    "            'reward_func': reward_fn,\n",
    "            'reference_sampler_func': sampler_fn,\n",
    "        })\n",
    "\n",
    "        params.update(loop_cfg['params'])\n",
    "\n",
    "        print(\"\\n\" + \"-\"*35)\n",
    "        print(f\"Running: {loop_type}\")\n",
    "        print(\"-\"*35)\n",
    "\n",
    "        results_data = loop_fn(**params)\n",
    "\n",
    "        print(f\"Completed {len(results_data['reward'])} iterations\")\n",
    "        if run_settings['run_mode'] == 'time' and 'time' in results_data:\n",
    "            print(f\"Total time: {run_settings['max_time_seconds']:.2f}s\")\n",
    "        print(f\"Final reward: {results_data['reward'][-1]:.3f}\")\n",
    "        if 'ess' in results_data:\n",
    "            print(f\"Final ESS: {results_data['ess'][-1]:.1f}\")\n",
    "        if 'gamma' in results_data:\n",
    "            print(f\"Final gamma: {float(results_data['gamma'][-1]):.4f}\")\n",
    "\n",
    "        exp_name = f\"{loop_type.title()} ({dist_config['name']})\"\n",
    "        results_for_this_plot[exp_name] = results_data\n",
    "        all_results[f\"{loop_type}_{dist_key}_{reward_key}\"] = results_data\n",
    "\n",
    "    plot_x_axis = 'time' if run_settings['run_mode'] == 'time' else 'step'\n",
    "    print(f\"\\n... Generating plot for {experiment_title} (x-axis: {plot_x_axis}) ...\")\n",
    "\n",
    "    plot_results(results_for_this_plot, plot_x_axis=plot_x_axis, lamb_kl=CONFIG_BASE['lamb_kl'])\n",
    "\n",
    "print(\"\\n\" + \"~\"*65)\n",
    "print(\"All experiments complete!\")\n"
   ]
  }
 ],
 "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.12.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
