{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "1af3b8dc",
   "metadata": {},
   "source": [
    "# GVI experiments for RAdaGD"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "802ae8f6",
   "metadata": {},
   "source": [
    "Main code references are from https://github.com/mzydiao/FBGVI, \n",
    "with additional modifications needed to implement our method."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3015b979",
   "metadata": {},
   "source": [
    "### Import libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7be4b603",
   "metadata": {},
   "outputs": [],
   "source": [
    "# math\n",
    "import math\n",
    "import numpy as np\n",
    "from numpy.random import multivariate_normal as mvn\n",
    "from scipy.stats import ortho_group, uniform, bernoulli\n",
    "from scipy.linalg import sqrtm, eigvalsh\n",
    "from scipy.optimize import minimize\n",
    "\n",
    "# plotting/visualization\n",
    "import matplotlib.pyplot as plt\n",
    "from brokenaxes import brokenaxes\n",
    "\n",
    "# python utils\n",
    "from functools import partial\n",
    "from jax import hessian"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c18e410",
   "metadata": {},
   "source": [
    "### Utils"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ef4c6e8",
   "metadata": {},
   "source": [
    "Basic matrix utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "cff4dac7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gen_matrix_with_eigs(eigs):\n",
    "    \"\"\"\n",
    "    Generates a symmetric matrix with eigenvalues `eigs`.\n",
    "    \"\"\"\n",
    "    dim = len(eigs)\n",
    "    x = ortho_group.rvs(dim)\n",
    "    return x.T @ np.diag(eigs) @ x\n",
    "\n",
    "def gen_matrix_with_eigbounds(low, high, dim: int):\n",
    "    \"\"\"\n",
    "    Generates a symmetric matrix with eigenvalues within [low, high].\n",
    "    \"\"\"\n",
    "    eigs = low + (high - low) * uniform.rvs(size=dim)\n",
    "    return gen_matrix_with_eigs(eigs)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7ca4b019",
   "metadata": {},
   "source": [
    "BW geometry related utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "2332597a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def grad_transport_map(Sigma_0, Sigma_1):\n",
    "  \"\"\"\n",
    "  Return Gradient of Transport map between N(0, Sigma_0), N(0,Sigma_1) = sqrt(0)^-1 @ sqrt(sqrt(0) @ 1 @ sqrt(0)) @ sqrt(0)^-1 = 0^-1 @ sqrt(0 @ 1)\n",
    "  https://math.stackexchange.com/questions/1117029/properties-of-the-matrix-square-root\n",
    "  \"\"\"\n",
    "  end = sqrtm(Sigma_0 @ Sigma_1)\n",
    "  return np.linalg.inv(Sigma_0) @ end\n",
    "\n",
    "def gaussian_composition(mu_1, a, S, b, R):\n",
    "  \"\"\"\n",
    "  Return the composition of the transport map at (a,S) in N(mu_1, Sigma_1) (a,S) circ (b,R)\n",
    "  \"\"\"\n",
    "  vec = a + S.dot(b) - S.dot(mu_1)\n",
    "  mat = S @ R\n",
    "  return vec, mat\n",
    "\n",
    "def gaussian_transport(Sigma_0, Sigma_1, a, S):\n",
    "  \"\"\"\n",
    "  Transports the vector (a,S) in T_Sigma_1 BW to T_Sigma_0 BW\n",
    "  \"\"\"\n",
    "  vec = a\n",
    "  mat = S @ grad_transport_map(Sigma_0, Sigma_1)\n",
    "  return vec, mat\n",
    "\n",
    "\n",
    "def gaussian_interpolation(mean_0, Sigma_0, mean_1, Sigma_1, t):\n",
    "  \"\"\"\n",
    "  Return interpolating Gaussian distribution\n",
    "  \"\"\"\n",
    "  mean_t = (1 - t) * mean_0 + t * mean_1\n",
    "  Sigma_t = ((1-t)**2) * Sigma_0 + t * (1-t) * (sqrtm(Sigma_0 @ Sigma_1) + sqrtm(Sigma_1 @ Sigma_0)) + (t ** 2) * Sigma_1\n",
    "  return mean_t, Sigma_t\n",
    "\n",
    "def bw_inner_product(a, S, b, R, Sigma):\n",
    "  vec = np.dot(a,b)\n",
    "  mat = np.linalg.trace(S @ Sigma @ R)\n",
    "  return vec + mat"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f25c3418",
   "metadata": {},
   "source": [
    "Misc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ff4b1b24",
   "metadata": {},
   "outputs": [],
   "source": [
    "def softmax(x):\n",
    "    \"\"\"\n",
    "    Univariate softmax function.\n",
    "    \"\"\"\n",
    "    return np.exp(x) / (1 + np.exp(x))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "06758c3e",
   "metadata": {},
   "source": [
    "Taget functional related utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0ed30717",
   "metadata": {},
   "outputs": [],
   "source": [
    "def V(mu_0, mu_1, Sigma_0, Sigma_1):\n",
    "  \"\"\"\n",
    "  Return E(V(X)) if V = (X-mu_1)^T Sigma_1 (X-mu_1)/2\n",
    "  https://statproofbook.github.io/P/mean-qf.html\n",
    "  \"\"\"\n",
    "  Sigma_1_inv = np.linalg.inv(Sigma_1)\n",
    "  first_term = (mu_0 - mu_1).T @ Sigma_1_inv @ (mu_0 - mu_1)\n",
    "  second_term = np.trace(Sigma_1_inv @ Sigma_0)\n",
    "  return first_term + second_term\n",
    "\n",
    "def H(mu, Sigma):\n",
    "    \"\"\"\n",
    "    Return E_q[log q(theta)] for q = N(mu, Sigma)\n",
    "    (i.e., the negative differential entropy).\n",
    "    \"\"\"\n",
    "    Sigma = 0.5 * (Sigma + Sigma.T)           # symmetrize\n",
    "    d = Sigma.shape[0]\n",
    "    sign, logdet = np.linalg.slogdet(Sigma)\n",
    "    if sign <= 0:\n",
    "      raise ValueError(\"Sigma must be SPD.\")\n",
    "    # E_q[log q] = -0.5 * [ d(1 + log(2π)) + log det Σ ]\n",
    "    return -0.5 * (d * (1.0 + np.log(2.0 * np.pi)) + logdet)\n",
    "\n",
    "def kl_divergence(mu_0, mu_1, Sigma_0, Sigma_1):\n",
    "  \"\"\"\n",
    "  Return the KL divergence\n",
    "  KL( N(mu_0, Sigma_0) || N(mu_1, Sigma_1) ).\n",
    "  \"\"\"\n",
    "  d = mu_0.shape[0]\n",
    "\n",
    "  det_0 = np.linalg.det(Sigma_0)\n",
    "  det_1 = np.linalg.det(Sigma_1)\n",
    "  Sigma_1_inv = np.linalg.inv(Sigma_1)\n",
    "  div = np.log(det_1) - np.log(det_0)\n",
    "  div -= d\n",
    "  div += (Sigma_1_inv * Sigma_0).sum()\n",
    "  div += (mu_1 - mu_0).T @ Sigma_1_inv @ (mu_1 - mu_0)\n",
    "  div /= 2\n",
    "  return div\n",
    "  # return V(mu_0, mu_1, Sigma_0, Sigma_1) + H(mu_0, Sigma_0)\n",
    "\n",
    "def wasserstein_dist(mu_0, mu_1, Sigma_0, Sigma_1):\n",
    "    \"\"\"\n",
    "    Return the squared W2 distance between N(mu_0, Sigma_0), N(mu_1, Sigma_1).\n",
    "    \"\"\"\n",
    "    half_0 = sqrtm(Sigma_0)\n",
    "    half_1 = sqrtm(Sigma_1)\n",
    "    return np.sum((mu_0 - mu_1) ** 2) + np.sum((half_0 - half_1) ** 2)\n",
    "\n",
    "def laplace_approx(dim, log_potential, grad_V, hess_V):\n",
    "  \"\"\"\n",
    "  Compute Laplace approximation to target distribution.\n",
    "  \"\"\"\n",
    "\n",
    "  x0 = np.zeros(dim)\n",
    "\n",
    "  # compute MAP\n",
    "  result = minimize(log_potential, x0, jac = grad_V, hess = hess_V)\n",
    "  mu = result.x\n",
    "\n",
    "  # compute Hessian at map\n",
    "  H = hess_V(mu)\n",
    "\n",
    "  # compute inverse of Hessian to obtain Sigma\n",
    "  Sigma = np.linalg.inv(H)\n",
    "\n",
    "  return mu, Sigma\n",
    "\n",
    "def empirical_kl(mu, Sigma, log_potential_pure, size = 1000):\n",
    "  \"\"\"\n",
    "  Compute the empirical KL divergence\n",
    "  to the unnormalized target as a distance objective.\n",
    "  \"\"\"\n",
    "  # draw random samples from N(mu, Sigma) to approximate F(p_k).\n",
    "  theta = mvn_safe(mu, Sigma, size = size).T\n",
    "\n",
    "  # compute empirical expectation of V\n",
    "  log_potentials = log_potential_pure(theta)\n",
    "  assert log_potentials.shape == (size, )\n",
    "  EE_V = log_potentials.mean()\n",
    "  return EE_V + H(mu, Sigma)\n",
    "\n",
    "def empirical_FI(mu, Sigma, grad_pure, size = 1000):\n",
    "    \"\"\"\n",
    "    Compute the empirical log Fisher information as a distance objective.\n",
    "    \"\"\"\n",
    "    Sigma_inv = safe_inv_spd(Sigma)\n",
    "\n",
    "    # x: (d, m)\n",
    "    x = mvn(mu, Sigma, size=size).T\n",
    "    d, m = x.shape\n",
    "\n",
    "    # grad_pure must support batched theta: (d, m) -> (m, d)\n",
    "    grad_stack = grad_pure(x)\n",
    "    if grad_stack.shape == (d, m):   # safety in case function returns (d,m)\n",
    "        grad_stack = grad_stack.T\n",
    "    # grad_stack: (m, d)\n",
    "\n",
    "    expected_grad = grad_stack.mean(axis=0)           # (d,)\n",
    "\n",
    "    # XC: centered samples, shape (m, d)\n",
    "    XC = (x.T - mu)\n",
    "\n",
    "    # integration-by-parts estimate of E[nabla^2 V]\n",
    "    expected_hess = 0.5 * (grad_stack.T @ XC) / m     # (d, d)\n",
    "    expected_hess = expected_hess @ Sigma_inv\n",
    "     # (optional: symmetrize)\n",
    "    expected_hess = 0.5 * (expected_hess + expected_hess.T)\n",
    "\n",
    "    # BW gradient estimate: shape (d, m)\n",
    "    bw_grad = (\n",
    "        expected_grad[:, None]              # (d,1) -> broadcast over m\n",
    "        + (XC @ expected_hess).T            # (d, m)\n",
    "        - (XC @ Sigma_inv).T                # (d, m)\n",
    "    )\n",
    "\n",
    "    return np.log((bw_grad ** 2).sum(axis=0).mean())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fc7f129a",
   "metadata": {},
   "source": [
    "### Wasserstein gradient descent module for KL minimization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "cd2753ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "# nabla 1 and nabla 2 gets the E(nabla V) and E(nabla^2 V)\n",
    "def one_step_grad(mu_k, Sigma_k, nabla_1, nabla_2, stepsize, dim, prox = False):\n",
    "  # mu update\n",
    "  mu_k = mu_k - stepsize * nabla_1\n",
    "  # Sigma update\n",
    "  if not prox:\n",
    "    # compute gradient in Sigma\n",
    "    Sigma_inv_k = np.linalg.inv(Sigma_k)\n",
    "    M = np.eye(dim) - stepsize * (nabla_2 - Sigma_inv_k)\n",
    "    Sigma_k = M @ Sigma_k @ M\n",
    "  else:\n",
    "    M_half = np.eye(dim) - stepsize * nabla_2\n",
    "    Sigma_half = M_half @ Sigma_k @ M_half\n",
    "    # do backward step for the entropy\n",
    "    sqrt_matrix = sqrtm(\n",
    "        Sigma_half @ (Sigma_half + 4 * stepsize * np.eye(dim))\n",
    "    )\n",
    "    sqrt_matrix = np.real(sqrt_matrix)\n",
    "    Sigma_k = 0.5 * (Sigma_half + 2 * stepsize * np.eye(dim) + sqrt_matrix)\n",
    "  return mu_k, Sigma_k"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ddc224ea",
   "metadata": {},
   "source": [
    "### Task 2: Poisson Regression"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8168b0d6",
   "metadata": {},
   "source": [
    "Target functional utils"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cfb25972",
   "metadata": {},
   "outputs": [],
   "source": [
    "def _theta_as_batch(theta, d):\n",
    "    \"\"\"Return (TH, was_single) where TH has shape (m, d).\"\"\"\n",
    "    th = np.asarray(theta)\n",
    "    if th.ndim == 1:\n",
    "        if th.shape[0] != d:\n",
    "            raise ValueError(f\"theta has shape {th.shape}, expected (d,) with d={d}\")\n",
    "        return th[None, :], True               # (1, d)\n",
    "    if th.ndim == 2:\n",
    "        if th.shape == (1, d):  return th, True\n",
    "        if th.shape == (d, 1):  return th.T, True\n",
    "        if th.shape[1] == d:    return th, False   # (m, d)\n",
    "        if th.shape[0] == d:    return th.T, False # (d, m) -> (m, d)\n",
    "    raise ValueError(f\"Unsupported theta shape {th.shape}; expected (d,), (m,d), or (d,m)\")\n",
    "\n",
    "# ---------------- Poisson negative log-likelihood pieces ----------------\n",
    "def log_potential_poisson(theta, Y, X):\n",
    "    \"\"\"\n",
    "    If theta is (d,), returns a scalar.\n",
    "    If theta is batched ((m,d) or (d,m)), returns (m,) values.\n",
    "    \"\"\"\n",
    "    n, d = X.shape\n",
    "    TH, was_single = _theta_as_batch(theta, d)          # (m, d)\n",
    "    Z = X @ TH.T                                        # (n, m)\n",
    "    # Z = np.clip(Z, -50.0, 50.0)\n",
    "    Lam = np.exp(Z)                                     # (n, m)\n",
    "    Y = np.asarray(Y).reshape(n)\n",
    "    vals = Lam.sum(axis=0) - (Y[:, None] * Z).sum(axis=0)   # (m,)\n",
    "    return vals[0] if was_single else vals\n",
    "\n",
    "def grad_V_poisson(theta, Y, X):\n",
    "    \"\"\"\n",
    "    \\nabla V(\\theta) = X^T (exp(X\\theta) - Y)\n",
    "    If theta is (d,), returns (d,).\n",
    "    If batched, returns (m, d).\n",
    "    \"\"\"\n",
    "    n, d = X.shape\n",
    "    TH, was_single = _theta_as_batch(theta, d)          # (m, d)\n",
    "    Z = X @ TH.T                                        # (n, m)\n",
    "    # Z = np.clip(Z, -50.0, 50.0)\n",
    "    Lam = np.exp(Z)                                     # (n, m)\n",
    "    Y = np.asarray(Y).reshape(n)\n",
    "    G = (Lam - Y[:, None]).T @ X                        # (m, d)\n",
    "    return G[0] if was_single else G\n",
    "\n",
    "def hess_V_poisson(theta, Y, X):\n",
    "    \"\"\"\n",
    "    \\nabla^2 V(\\theta) = X^T diag(exp(X\\theta)) X\n",
    "    If theta is (d,), returns (d, d).\n",
    "    If batched, returns (m, d, d).\n",
    "    \"\"\"\n",
    "    n, d = X.shape\n",
    "    TH, was_single = _theta_as_batch(theta, d)          # (m, d)\n",
    "    Z = X @ TH.T                                        # (n, m)\n",
    "    # Z = np.clip(Z, -50.0, 50.0)\n",
    "    Lam = np.exp(Z)                                     # (n, m)\n",
    "    # H[m, :, :] = sum_i lam[i, m] * x_i x_i^T\n",
    "    H = np.einsum('ni,nj,nm->mij', X, X, Lam)           # (m, d, d)\n",
    "    return H[0] if was_single else H\n",
    "\n",
    "def make_poisson_gaussian_moments(X, Y):\n",
    "    \"\"\"\n",
    "    Given data, return an oracle that reproduces EV, E\\nabla V, E\\nabla^2 V\n",
    "    \"\"\"\n",
    "    X = np.asarray(X)\n",
    "    y = np.asarray(Y)\n",
    "\n",
    "    def moments(mu, Sigma, clip=None):\n",
    "        # s2 = diag(X \\Sigma X^T) computed vectorially\n",
    "        XS = X @ Sigma                       # (n,d)\n",
    "        s2 = np.einsum('nd,nd->n', XS, X)    # (n,)\n",
    "        s = X @ mu + 0.5 * s2                 # (n,)\n",
    "        if clip is not None:                 # optional numerical guard\n",
    "            s = np.clip(s, -clip, clip)\n",
    "        lam_bar = np.exp(s)                  # (n,)\n",
    "\n",
    "        EV     = lam_bar.sum() - Y @ (X @ mu)                 # scalar\n",
    "        Egrad  = X.T @ (lam_bar - Y)                         # (d,)\n",
    "        EHess  = X.T @ (lam_bar[:, None] * X)                # (d,d)\n",
    "        return EV, Egrad, EHess\n",
    "\n",
    "    return moments"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6685ed7e",
   "metadata": {},
   "source": [
    "### Wasserstein GD for glm regression Module"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1a19f678",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<>:5: SyntaxWarning: invalid escape sequence '\\m'\n",
      "<>:5: SyntaxWarning: invalid escape sequence '\\m'\n",
      "C:\\Users\\Public\\Documents\\ESTsoft\\CreatorTemp\\ipykernel_1016\\3596875660.py:5: SyntaxWarning: invalid escape sequence '\\m'\n",
      "  Conduct GD for KL(\\mu || \\pi) = V(\\mu) + H(\\mu) on GLM, given the oracle\n"
     ]
    }
   ],
   "source": [
    "def wasser_gds_glm(dim, glm_gaussian_moment_ftn, num_iter,\n",
    "                       step_size = 1, adaptive = True, ours = True, A_order = 0, armijo = False, \n",
    "                       prox = False, init_mu = None, init_Sigma = None, delta =  1e-7):\n",
    "  \"\"\"\n",
    "  Conduct GD for KL(\\mu || \\pi) = V(\\mu) + H(\\mu) on GLM, given the oracle\n",
    "  \"\"\"\n",
    "  # create a list to save the result\n",
    "  gd_kl_list = []\n",
    "  gd_FI_list = []\n",
    "  # create a step-size list\n",
    "  stepsize_list = []\n",
    "  # eigenvalue list\n",
    "  eigenvalue_list = []\n",
    "\n",
    "  if armijo:\n",
    "    extra_bt = []\n",
    "\n",
    "  # initialize\n",
    "  if init_mu is None:\n",
    "    gd_mu_k = np.zeros(dim)\n",
    "  else:\n",
    "    gd_mu_k = init_mu\n",
    "  if init_Sigma is None:\n",
    "    gd_Sigma_k = np.eye(dim)\n",
    "  else:\n",
    "    gd_Sigma_k = init_Sigma\n",
    "\n",
    "  # save the initial result: log error\n",
    "  EV, _, _ = glm_gaussian_moment_ftn(gd_mu_k, gd_Sigma_k)\n",
    "  current_gd_kl = EV + H(gd_mu_k, gd_Sigma_k)\n",
    "  gd_kl_list.append(current_gd_kl)\n",
    "\n",
    "  # For adaptive methods\n",
    "  list_len = num_iter + 2\n",
    "  A = [None] * (list_len)\n",
    "  B = [None] * (list_len)\n",
    "  for i in range(list_len):\n",
    "    if A_order == 1:\n",
    "      A[i] = (i+5)/2\n",
    "      B[i] = (i+1)/2\n",
    "    elif A_order == 0.5:\n",
    "      a = 2\n",
    "      A[i] = 2 * np.sqrt(i+a) + 2\n",
    "      B[i] = 2 * np.sqrt(i+a-2) - 2 + (5 / (1 + 2 * np.sqrt(i+a-2)))\n",
    "    elif A_order == 0:\n",
    "      A[i] = 3\n",
    "      B[i] = 5/4\n",
    "    else:\n",
    "      a = 2\n",
    "      A[i] = 2 * np.power(i+a, A_order) + 2\n",
    "      B[i] = A[i] - 2\n",
    "  s0 = step_size\n",
    "  s_t1 = s0\n",
    "  L_e = L\n",
    "  theta_t = 0\n",
    "  s_prev = s_t1\n",
    "\n",
    "  # run the gradient methods\n",
    "  for curr_iter in range(2, num_iter + 1):\n",
    "    # calculate gradient\n",
    "    EV, gd_nabla_1, gd_nabla_2 = glm_gaussian_moment_ftn(gd_mu_k, gd_Sigma_k)\n",
    "    # add smallest eigenvalue for logging\n",
    "    eigenvalue_list.append((eigvalsh(gd_Sigma_k, subset_by_index=(0, 0), driver='evr', check_finite=False)[0]))\n",
    "    # compute adaptive stepsize\n",
    "    if adaptive:\n",
    "      if ours:\n",
    "        grad_vec_old = gd_nabla_1\n",
    "        grad_mat_old = gd_nabla_2 - np.linalg.inv(gd_Sigma_k)\n",
    "        lam_max = eigvalsh(grad_mat_old, subset_by_index=(dim-1, dim-1), driver='evr', check_finite=False)[0]\n",
    "        lam_min = eigvalsh(grad_mat_old, subset_by_index=(0, 0),     driver='evr', check_finite=False)[0]\n",
    "        t= curr_iter\n",
    "        s_prev = s_t1\n",
    "        if t == 0:\n",
    "          s_t1 = min( 1/A[0] * s_prev, A[0] * B[0] / ( A[0]**2 + B[0] * (B[1] + 1) ) * 1/L_e)\n",
    "        elif t >= 1:\n",
    "          t = t+1\n",
    "          r_s = (A[t-2]+1)/A[t-1]\n",
    "          if L_e > 0:\n",
    "            #if s_prev >= (1/L_e):\n",
    "            r_l = A[t-1] * B[t-1] / ( A[t-1]**2 + B[t-1] * (B[t] + 1) )\n",
    "            # else:\n",
    "            #   r_l = A[t-1]/(B[t] + 1)\n",
    "            s_t1 = min( r_s * s_prev, r_l * 1/L_e, (1-delta)/(max(abs(lam_min), abs(lam_max))))\n",
    "          else:\n",
    "            s_t1 = min(r_s * s_prev, (1-delta)/(max(abs(lam_min), abs(lam_max))))\n",
    "\n",
    "        # adaptive GD update\n",
    "        stepsize_list.append(s_t1)\n",
    "        f_old = EV + H(gd_mu_k, gd_Sigma_k)\n",
    "        gd_mu_next, gd_Sigma_next = one_step_grad(gd_mu_k, gd_Sigma_k, gd_nabla_1, gd_nabla_2, s_t1, dim, prox = False)\n",
    "        # gd_Sigma_next = enforce_spd(gd_Sigma_next)\n",
    "        EV_next, gd_nabla_1_next, gd_nabla_2_next = glm_gaussian_moment_ftn(gd_mu_next, gd_Sigma_next)\n",
    "        f_new = EV_next + H(gd_mu_next, gd_Sigma_next)\n",
    "\n",
    "        # compute adaptive stepsize\n",
    "        grad_vec_new = gd_nabla_1_next\n",
    "        grad_mat_new = gd_nabla_2_next - np.linalg.inv(gd_Sigma_next)\n",
    "        g_new = gaussian_transport(\n",
    "            gd_Sigma_k, gd_Sigma_next, grad_vec_new, grad_mat_new\n",
    "        )\n",
    "        g_old = (grad_vec_old, grad_mat_old)\n",
    "        numerator = bw_inner_product(g_old[0] - g_new[0], g_old[1] - g_new[1], g_old[0] - g_new[0], g_old[1] - g_new[1], gd_Sigma_k)\n",
    "        if numerator == 0:\n",
    "          L_e = 0\n",
    "        else:\n",
    "          denominator = -2*(f_new - f_old + s_t1 * bw_inner_product(g_old[0], g_old[1], g_new[0], g_new[1], gd_Sigma_k))\n",
    "          L_e = np.exp(np.log(numerator) - np.log(denominator))\n",
    "          if L_e < 0 or (math.isnan(L_e)):\n",
    "            L_e = 0\n",
    "      # Malitsky\n",
    "      else:\n",
    "        stepsize_list.append(s_t1)\n",
    "        # gradient step\n",
    "        gd_mu_next, gd_Sigma_next = one_step_grad(\n",
    "            gd_mu_k, gd_Sigma_k, gd_nabla_1, gd_nabla_2, s_t1, dim, prox=False\n",
    "        )\n",
    "        # gd_Sigma_next = enforce_spd(gd_Sigma_next)\n",
    "\n",
    "        _, gd_nabla_1_next, gd_nabla_2_next = glm_gaussian_moment_ftn(\n",
    "            gd_mu_next, gd_Sigma_next\n",
    "        )\n",
    "        grad_vec_next = gd_nabla_1_next\n",
    "        grad_mat_next = gd_nabla_2_next - np.linalg.inv(gd_Sigma_next)\n",
    "\n",
    "        # old gradient at x_k (split like you already do)\n",
    "        grad_vec_old = gd_nabla_1\n",
    "        grad_mat_old = gd_nabla_2 - np.linalg.inv(gd_Sigma_k)\n",
    "\n",
    "        # transport old → new, and measure differences at the NEW base point\n",
    "        g_old_on_new = gaussian_transport(\n",
    "            gd_Sigma_next, gd_Sigma_k, grad_vec_old, grad_mat_old\n",
    "        )\n",
    "        prev_vec_on_new, prev_mat_on_new = g_old_on_new\n",
    "\n",
    "        # Riemannian norms (not squared) with correct base points\n",
    "        norm_prev_sq = bw_inner_product(\n",
    "            grad_vec_old, grad_mat_old, grad_vec_old, grad_mat_old, gd_Sigma_k\n",
    "        )\n",
    "        if norm_prev_sq >= 0:\n",
    "          norm_prev = math.sqrt(norm_prev_sq)\n",
    "        else:\n",
    "          norm_prev = 0\n",
    "        diff_vec = grad_vec_next - prev_vec_on_new\n",
    "        diff_mat = grad_mat_next - prev_mat_on_new\n",
    "        norm_diff_sq = bw_inner_product(diff_vec, diff_mat, diff_vec, diff_mat, gd_Sigma_next)\n",
    "        if norm_diff_sq >= 0:\n",
    "          norm_diff = math.sqrt(norm_diff_sq)\n",
    "        else:\n",
    "          norm_diff = 0\n",
    "\n",
    "        if (norm_diff == 0.0) or math.isnan(norm_diff):\n",
    "            s_next = math.sqrt(1.0 + theta_t) * s_prev\n",
    "\n",
    "        else:\n",
    "            L_e_inv = (s_prev * norm_prev) / (math.sqrt(2.0) * norm_diff)\n",
    "            s_next = min(math.sqrt(1.0 + theta_t) * s_prev, L_e_inv)\n",
    "\n",
    "        theta_t = 0.0 if s_prev == 0.0 else (s_next / s_prev)\n",
    "\n",
    "        s_prev = s_next\n",
    "        s_t1   = s_next\n",
    "\n",
    "      gd_mu_k, gd_Sigma_k = gd_mu_next, gd_Sigma_next\n",
    "    \n",
    "    elif armijo:\n",
    "      # armijo_coeff = 10**(-6)\n",
    "      armijo_coeff = 10**(-4)\n",
    "      # armijo_coeff = 10**(-2)\n",
    "      # armijo_coeff = 10**(-1)\n",
    "      backtracking_factor = 0.5\n",
    "      # backtracking_factor = 0.8\n",
    "      step_size = 1\n",
    "      max_backtracks = 40\n",
    "      bt = 0\n",
    "\n",
    "      grad_vec_old = gd_nabla_1\n",
    "      grad_mat_old = gd_nabla_2 - np.linalg.inv(gd_Sigma_k)\n",
    "      f_old = EV + H(gd_mu_k, gd_Sigma_k)\n",
    "      g_old = (grad_vec_old, grad_mat_old)\n",
    "\n",
    "      while True:\n",
    "        gd_mu_next, gd_Sigma_next = one_step_grad(\n",
    "            gd_mu_k, gd_Sigma_k, gd_nabla_1, gd_nabla_2, step_size, dim, prox=False\n",
    "        )\n",
    "\n",
    "        EV_next, gd_nabla_1_next, gd_nabla_2_next = glm_gaussian_moment_ftn(\n",
    "            gd_mu_next, gd_Sigma_next\n",
    "        )\n",
    "        f_new = EV_next + H(gd_mu_next, gd_Sigma_next)\n",
    "\n",
    "        grad_vec_new = gd_nabla_1_next\n",
    "        grad_mat_new = gd_nabla_2_next - np.linalg.inv(gd_Sigma_next)\n",
    "        g_new = gaussian_transport(\n",
    "            gd_Sigma_k, gd_Sigma_next, grad_vec_new, grad_mat_new\n",
    "        )\n",
    "\n",
    "        grad_square = bw_inner_product(\n",
    "            g_old[0], g_old[1], g_old[0], g_old[1], gd_Sigma_k\n",
    "        )\n",
    "\n",
    "        if f_new - f_old <= -armijo_coeff * step_size * grad_square:\n",
    "            break\n",
    "\n",
    "        bt += 1\n",
    "        if bt >= max_backtracks:\n",
    "            break\n",
    "\n",
    "        step_size *= backtracking_factor  \n",
    "      stepsize_list.append(step_size)\n",
    "      gd_mu_k, gd_Sigma_k = gd_mu_next, gd_Sigma_next      \n",
    "      extra_bt.append(bt)\n",
    "\n",
    "    # Conduct Forward-Backward BWVI\n",
    "    else:\n",
    "      if prox:\n",
    "        # Forward-backward update\n",
    "        gd_mu_k, gd_Sigma_k = one_step_grad(gd_mu_k, gd_Sigma_k, gd_nabla_1, gd_nabla_2, step_size, dim, prox = True)\n",
    "      else:\n",
    "        # Wasserstein GD\n",
    "        gd_mu_k, gd_Sigma_k = one_step_grad(gd_mu_k, gd_Sigma_k, gd_nabla_1, gd_nabla_2, step_size, dim, prox = False)\n",
    "      # gd_Sigma_k = enforce_spd(gd_Sigma_k)\n",
    "      stepsize_list.append(step_size)\n",
    "\n",
    "    # save the initial result: log error\n",
    "    EV, _, _ = glm_gaussian_moment_ftn(gd_mu_k, gd_Sigma_k)\n",
    "    current_gd_kl = EV + H(gd_mu_k, gd_Sigma_k)\n",
    "    gd_kl_list.append(current_gd_kl)\n",
    "\n",
    "  # save the last result\n",
    "  gd_mu_last = gd_mu_k\n",
    "  gd_Sigma_last = gd_Sigma_k\n",
    "\n",
    "  # return the result\n",
    "  if armijo:\n",
    "    return gd_kl_list, gd_FI_list, gd_mu_last, gd_Sigma_last, stepsize_list, eigenvalue_list, extra_bt\n",
    "  return gd_kl_list, gd_FI_list, gd_mu_last, gd_Sigma_last, stepsize_list, eigenvalue_list"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ced87b3",
   "metadata": {},
   "source": [
    "### Simulations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d6e6364",
   "metadata": {},
   "source": [
    "Synthetic data generations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "873da5ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.random.seed(100)\n",
    "\n",
    "num_sample, dim = 50, 25\n",
    "X = mvn(np.zeros(dim), np.eye(dim), size=(num_sample))    # (n, d)\n",
    "\n",
    "# optional global scaling (keeps conditioning manageable)\n",
    "maxeig = np.linalg.eigvalsh(X.T @ X).max()\n",
    "X = X / np.sqrt(maxeig)\n",
    "\n",
    "# --- true parameter and Poisson outcomes -----------------------------------\n",
    "true_theta = mvn(np.zeros(dim), np.eye(dim))                 # (d,)\n",
    "z_true = X @ true_theta\n",
    "# z_true = np.clip(z_true, -8.0, 8.0)                          # keep rates sane\n",
    "lam_true = np.exp(z_true)                                    # (n,)\n",
    "Y = np.random.poisson(lam_true)                              # (n,)\n",
    "\n",
    "poisson_gaussian_moment_ftn = make_poisson_gaussian_moments(X, Y)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cfffe1f5",
   "metadata": {},
   "source": [
    "Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0acca71f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FB Done\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Public\\Documents\\ESTsoft\\CreatorTemp\\ipykernel_1016\\3596875660.py:107: RuntimeWarning: invalid value encountered in log\n",
      "  L_e = np.exp(np.log(numerator) - np.log(denominator))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AdaGDO(n) Done\n",
      "AdaGDO(0.1)) Done\n",
      "large_L FB Done\n",
      "small_L FB Done\n",
      "Armijo\n"
     ]
    }
   ],
   "source": [
    "# Guess L\n",
    "L = 2\n",
    "small_L = L/2\n",
    "large_L = 2 * L\n",
    "\n",
    "# Experiment setup\n",
    "num_subiter = 1000\n",
    "A_order_experi = 0.1\n",
    "\n",
    "# run experiment\n",
    "fb_kl_list, fb_FI_list, fb_mu_last_j, fb_Sigma_last_j, stepsize_fb, eigenvalue_fb  = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/L, adaptive = False, prox = True\n",
    "    )\n",
    "print(\"FB Done\")\n",
    "\n",
    "adap_gd_kl_list_a1, adap_gd_FI_list_a1, adap_gd_mu_last_j_a1, adap_gd_Sigma_last_j_a1, stepsize_a1, eigenvalue_a1 = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/L, adaptive = True, A_order = 1\n",
    "  )\n",
    "print(\"AdaGDO(n) Done\")\n",
    "\n",
    "adap_gd_kl_list_a01, adap_gd_FI_list_a01, adap_gd_mu_last_j_a01, adap_gd_Sigma_last_j_a01, stepsize_a01, eigenvalue_a01 = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/L, adaptive = True, A_order = A_order_experi\n",
    "  )\n",
    "print(f\"AdaGDO({A_order_experi})) Done\")\n",
    "\n",
    "fb_kl_list_large_L, fb_FI_list_large_L, fb_mu_last_j_large_L, fb_Sigma_last_j_large_L, stepsize_fb_large_L, eigenvalue_fb_large_L  = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/large_L, adaptive = False, prox = True\n",
    "    )\n",
    "print(\"large_L FB Done\")\n",
    "\n",
    "fb_kl_list_small_L, fb_FI_list_small_L, fb_mu_last_j_small_L, fb_Sigma_last_j_small_L, stepsize_fb_small_L, eigenvalue_fb_small_L  = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/small_L, adaptive = False, prox = True\n",
    "    )\n",
    "print(\"small_L FB Done\")\n",
    "\n",
    "armijo_kl_list, armijo_FI_list_small_L, armijo_last_j_small_L, armijo_Sigma_last_j, stepsize_armijo, eigenvalue_armijo, extra_bt  = wasser_gds_glm(\n",
    "    dim, poisson_gaussian_moment_ftn, num_subiter, step_size=1/small_L, adaptive = False, armijo=True, prox = False\n",
    "    )\n",
    "print(\"Armijo\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ebc18bc",
   "metadata": {},
   "source": [
    "Additional function call for the Armijo method"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "07d162ba",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6811"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum(extra_bt)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "00ab0439",
   "metadata": {},
   "source": [
    "Laplace approximation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "57082407",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\Public\\Documents\\ESTsoft\\CreatorTemp\\ipykernel_1016\\3296946138.py:58: RuntimeWarning: Method BFGS does not use Hessian information (hess).\n",
      "  result = minimize(log_potential, x0, jac = grad_V, hess = hess_V)\n"
     ]
    }
   ],
   "source": [
    "# Laplace approximation\n",
    "log_potential_pure = partial(log_potential_poisson, Y=Y, X=X)\n",
    "grad_pure = partial(grad_V_poisson, Y=Y, X=X)\n",
    "hess_pure = partial(hess_V_poisson, Y=Y, X=X)\n",
    "laplace_kl_list = []\n",
    "laplace_FI_list = []\n",
    "la_mu, la_Sigma = laplace_approx(dim, log_potential_pure, grad_pure, hess_pure)\n",
    "EV, _, _ = poisson_gaussian_moment_ftn(la_mu, la_Sigma)\n",
    "la_kl = EV + H(la_mu, la_Sigma)\n",
    "# la_FI = empirical_FI(la_mu, la_Sigma, grad_pure, size = 10000)\n",
    "for i in range(num_subiter):\n",
    "  laplace_kl_list.append(la_kl)\n",
    "  # laplace_FI_list.append(la_FI)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d6aee3f4",
   "metadata": {},
   "source": [
    "### Plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "1997942e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "iterations = list(range((num_subiter)))  # Create the x-axis (iteration numbers)\n",
    "\n",
    "colors = ['blue', 'green', \"purple\", \"darkcyan\", \"red\", \"olive\", \"brown\"]\n",
    "labels = [f\"FBGVI (s = 1/{L})\", f\"FBGVI (s = 1/{small_L})\", f\"FBGVI (s = 1/{large_L})\",\n",
    "          r\"RAdaGD $O(k)$\", fr\"RAdaGD $O(k^{{{A_order_experi}}})$\", \n",
    "          \"Laplace Approximation\", \"Armijo line search\"] # Labels for the legend\n",
    "\n",
    "min_value_fb_small_L = np.min(fb_kl_list_small_L)\n",
    "min_value_armijo = np.min(armijo_kl_list)\n",
    "min_value_fb_large_L = np.min(fb_kl_list_large_L)\n",
    "min_value_fb = np.min(fb_kl_list)\n",
    "min_value_a01 = np.min(adap_gd_kl_list_a01)\n",
    "min_value = min(min_value_fb, min_value_a01, min_value_fb_small_L, min_value_fb_large_L, min_value_armijo)\n",
    "\n",
    "plt.plot(iterations, fb_kl_list - min_value, color=colors[0], label=labels[0],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, fb_kl_list_small_L - min_value, color=colors[1], label=labels[1],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, fb_kl_list_large_L - min_value, color=colors[2], label=labels[2], \n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, adap_gd_kl_list_a1 - min_value, color=colors[3], label=labels[3],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, adap_gd_kl_list_a01 - min_value, color=colors[4], label=labels[4],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, laplace_kl_list - min_value, color=colors[5], label=labels[5],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "plt.plot(iterations, armijo_kl_list - min_value, color=colors[6], label=labels[6],\n",
    "         linestyle = '-', alpha = 0.5)\n",
    "\n",
    "# Add labels and title\n",
    "plt.xlabel(r\"Iteration $k$\")\n",
    "plt.ylabel(r\"$\\mathcal{F}(\\mu_k) - \\mathcal{F}_{{min}}$\")\n",
    "plt.title(\"Poisson regression GVI function value\" )\n",
    "plt.xscale('log',base=10)\n",
    "plt.yscale('log', base = 10)\n",
    "\n",
    "# Add a legend\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.grid(True)\n",
    "\n",
    "# Save as PDF\n",
    "plt.savefig(\"poisson_regression_gvi_linesearch.pdf\", format='pdf', bbox_inches='tight')\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "adanag",
   "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.13.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
