{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a0e65932",
   "metadata": {},
   "outputs": [],
   "source": [
    "import ot\n",
    "import ternary\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import jax.random as jr\n",
    "\n",
    "from tqdm import trange\n",
    "from ternary.helpers import project_sequence\n",
    "\n",
    "from lib_jax.estimator_entropy import ent\n",
    "from lib_jax.gd import mirror_descent\n",
    "from lib_jax.mirror_langevin import mirror_langevin\n",
    "from lib_jax.utils_plot import plot_trajectory\n",
    "from lib_jax.mirror_maps import EntropicMirror, EuclideanMirror"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c8be48bd",
   "metadata": {},
   "source": [
    "### Target"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e84a21d7",
   "metadata": {},
   "source": [
    "Dirichlet distribution from [1] (https://github.com/vishwakftw/metropolis-adjusted-MLA/tree/main).\n",
    "\n",
    "The goal is to sample from a distribution $\\nu\\propto \\exp\\big(-V(x)\\big)$ with potential $V(x) = - \\sum_{i=1}^d a_i \\log(x_i) - a_{d+1} \\log(1-\\sum_{i=1}^d x_i)$, i.e. a Dirichlet distribution.\n",
    "\n",
    "We will use the KL to learn it, i.e. $\\mathcal{F}(\\mu) = \\int V\\ \\mathrm{d}\\mu + \\int \\log (\\mu(x))\\ \\mathrm{d}\\mu(x)$. To stay on the (open) simplex $\\Delta_d =\\{x\\in \\mathbb{R}^{d+1}, x_i>0, \\sum_{i=1}^{d+1} x_i < 1\\}$, we can use a mirror map.\n",
    "\n",
    "Here we use $\\psi(x) = \\sum_{i=1}^d x_i \\log(x_i) + (1-\\sum_i x_i) \\log (1-\\sum_i x_i)$ for which we have\n",
    "\\begin{align}\n",
    "    & \\nabla \\psi(x) = \\Big(\\log x_i - \\log(1-\\sum_j x_j)\\Big)_i \\\\\n",
    "    & \\nabla \\psi^*(y) = \\left(\\frac{e^{y_i}}{1+\\sum_j e^{y_j}}\\right)_i.\n",
    "\\end{align}\n",
    "\n",
    "The scheme here is given by\n",
    "\\begin{equation}\n",
    "    T_{k+1} = \\nabla \\psi^*\\circ (\\nabla\\psi - \\gamma \\nabla_{W_2}\\mathcal{F}(\\mu_k)),\n",
    "\\end{equation}\n",
    "where $\\nabla\\mathcal{F}(\\mu_k) = \\nabla V + \\nabla \\log \\mu_k$, with the density of $\\mu_k$ estimated through a Kernel Density Estimator.\n",
    "\n",
    "[1] Srinivasan, Vishwak, Andre Wibisono, and Ashia Wilson. \"Fast sampling from constrained spaces using the Metropolis-adjusted Mirror Langevin Algorithm.\" arXiv preprint arXiv:2312.08823 (2023)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "15758362",
   "metadata": {},
   "outputs": [],
   "source": [
    "d = 2\n",
    "alpha = np.full((d + 1,), 6.0) \n",
    "\n",
    "def V(x):    \n",
    "    cpt1 = - jnp.sum(alpha[:-1] * jnp.log(x), axis=-1, keepdims=True)\n",
    "    cpt2 = - alpha[-1] * jnp.log(jnp.clip(1-jnp.sum(x, axis=-1, keepdims=True), 1e-8))\n",
    "    return cpt1 + cpt2\n",
    "\n",
    "@jax.jit\n",
    "def target(x):\n",
    "    out = V(x) - ent(x)\n",
    "    return jnp.mean(out)\n",
    "\n",
    "@jax.jit\n",
    "def grad_target_V(x):    \n",
    "    return sum_V(x)\n",
    "\n",
    "@jax.jit\n",
    "def sum_V(x):\n",
    "    return jnp.sum(V(x))\n",
    "\n",
    "@jax.jit\n",
    "def sum_kde(x):\n",
    "    kde = jax.scipy.stats.gaussian_kde(x.T)\n",
    "    logpdf = kde.logpdf(x.T)\n",
    "    return jnp.sum(logpdf)\n",
    "\n",
    "@jax.jit\n",
    "def grad_target(x):    \n",
    "    return sum_V(x) + sum_kde(x)\n",
    "\n",
    "@jax.jit\n",
    "def target_V(x):\n",
    "    out = V(x)\n",
    "    return jnp.mean(out)\n",
    "\n",
    "target_grad = jax.jit(jax.grad(grad_target))\n",
    "target_grad_V = jax.jit(jax.grad(grad_target_V))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8a083f3d",
   "metadata": {},
   "source": [
    "### Mirror Descent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "21a6e2b7-0bc7-45d8-9cca-08ce591d2625",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "An NVIDIA GPU may be present on this machine, but a CUDA-enabled jaxlib is not installed. Falling back to cpu.\n"
     ]
    }
   ],
   "source": [
    "n_epochs = 201 # 1001\n",
    "lr = 1e-3\n",
    "n_particles = 100\n",
    "d = 2\n",
    "\n",
    "rng = jax.random.PRNGKey(0)\n",
    "master_key, key = jax.random.split(rng, 2)\n",
    "\n",
    "\n",
    "# initialise from [1/2d, 1/2d ....] +/- epsilon * [1/24d, 1/24d, ....]\n",
    "x0 = np.full((n_particles, d), fill_value=1 / (2 * d))\n",
    "x0 += jax.random.uniform(key, (n_particles, d)) / (12 * d) - 1 / (24 * d)\n",
    "\n",
    "# x0 = np.random.rand(n_particles, d) / 2\n",
    "\n",
    "mirror_euc = EuclideanMirror()\n",
    "mirror = EntropicMirror()\n",
    "\n",
    "particles_gd, grads_gd = mirror_descent(target_grad, n_epochs=n_epochs, lr=lr, mirror=mirror_euc, x0=x0)\n",
    "particles_md, grads_md = mirror_descent(target_grad, n_epochs=n_epochs, lr=lr, mirror=mirror, x0=x0)\n",
    "particles_mld, grads_mld = mirror_langevin(key, target_grad_V, n_epochs=n_epochs, lr=lr, mirror=mirror, x0=x0, bar=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "989634ed-a739-42f8-b781-bed25dc8fe73",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/clement/anaconda3/envs/py311/lib/python3.11/site-packages/ternary/plotting.py:148: UserWarning: No data for colormapping provided via 'c'. Parameters 'vmin', 'vmax' will be ignored\n",
      "  ax.scatter(xs, ys, vmin=vmin, vmax=vmax, **kwargs)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "alpha_tgt = np.full((d + 1,), 6.0) \n",
    "x_target = np.random.dirichlet(alpha_tgt, size=100)\n",
    "\n",
    "figure, ax = plt.subplots(1, 4, figsize=(12, 3))\n",
    "\n",
    "# plt.gcf().subplots_adjust(wspace=0)\n",
    "\n",
    "tax0 = ternary.TernaryAxesSubplot(ax=ax[0])\n",
    "tax1 = ternary.TernaryAxesSubplot(ax=ax[1])\n",
    "tax2 = ternary.TernaryAxesSubplot(ax=ax[2])\n",
    "tax3 = ternary.TernaryAxesSubplot(ax=ax[3])\n",
    "\n",
    "\n",
    "tax0.boundary(linewidth=2.0)\n",
    "tax0.scatter(particles_md[0], color=\"blue\", s=0.1)\n",
    "tax0.set_title(\"Initial particles\", fontsize=13)\n",
    "\n",
    "tax1.boundary(linewidth=2.0)\n",
    "tax1.scatter(particles_md[-1], color=\"red\", s=10.0)\n",
    "tax1.set_title(\"Final particles MD\", fontsize=13)\n",
    "\n",
    "tax2.boundary(linewidth=2.0)\n",
    "tax2.scatter(particles_mld[-1], color=\"red\", s=10.0)\n",
    "tax2.set_title(\"Final particles MLD\", fontsize=13)\n",
    "\n",
    "tax3.boundary(linewidth=2.0)\n",
    "tax3.scatter(x_target, color=\"orange\", s=10.0)\n",
    "tax3.set_title(\"Groundtruth\", fontsize=13)\n",
    "\n",
    "ax[0].axis(\"off\")\n",
    "ax[1].axis(\"off\")\n",
    "ax[2].axis(\"off\")\n",
    "ax[3].axis(\"off\")\n",
    "\n",
    "# plt.savefig(\"./Figures/samples_dirichlet.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba1e88a4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "9a7e1c13",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "n_epochs = 201 # 1001\n",
    "lr = 1e-3\n",
    "n_particles = 100\n",
    "d = 2\n",
    "\n",
    "mirror_euc = EuclideanMirror()\n",
    "mirror_ent = EntropicMirror()\n",
    "\n",
    "ntry = 20\n",
    "\n",
    "rng = jax.random.PRNGKey(0)\n",
    "keys = jax.random.split(rng, ntry)\n",
    "\n",
    "L_md = np.zeros((ntry, n_epochs))\n",
    "L_mld = np.zeros((ntry, n_epochs))\n",
    "\n",
    "\n",
    "for i, key in enumerate(keys):    \n",
    "    # initialise from [1/2d, 1/2d ....] +/- epsilon * [1/24d, 1/24d, ....]\n",
    "    x0 = np.full((n_particles, d), fill_value=1 / (2 * d))\n",
    "    x0 += jax.random.uniform(key, (n_particles, d)) / (12 * d) - 1 / (24 * d)\n",
    "    \n",
    "    # particles_gd, grads_gd = mirror_descent(target_grad, n_epochs=n_epochs, lr=lr, mirror=mirror_euc, x0=x0)\n",
    "    particles_md, grads_md = mirror_descent(target_grad, n_epochs=n_epochs, lr=lr, mirror=mirror_ent, x0=x0)\n",
    "    particles_mld, grads_mld = mirror_langevin(key, target_grad_V, n_epochs=n_epochs, lr=lr, mirror=mirror_ent, x0=x0, bar=False)\n",
    "    \n",
    "    for k in range(n_epochs):\n",
    "        L_md[i, k] = target(particles_md[k])\n",
    "        L_mld[i, k] = target(particles_mld[k])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "44135761",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LFmyBABQWlqKZ555BpMnT0ZMTAz0ej3Gjh2LV155xTO1EQCsWrUKy5cvBwB89atf9dTp0Ucf9dQ5kE+5qakJzz33HIYNGwadTofk5GQ8/PDDKCoqanPOyvbr1q3DuHHjoNPpkJWVhV/96ldtzunzzz/HbbfdhuTkZOj1eqSlpWHRokU4cOBAUG3NDGzYfcH0CmPGjMHvf/97PPXUU7jjjjs807NHRER4yvz0pz/FL3/5S9x66634xS9+AZVKhU2bNuGb3/wm/vznP2PFihV++zx8+DDef/99fOc738EjjzziWX78+HF88MEHuOOOOzBs2DA4HA5s374dzz77LC5evIi//vWvAIA777wTZWVl+Nvf/obnn38eY8aMAQAMGzas3fNwOBxYuHAh9u3bh2984xt45plncOHCBaxduxY7duzA4cOH/WatAIDXXnsNFRUV+Na3voXo6Gi89dZb+MlPfoL09HTcf//9AChp+oIFC5CcnIzvf//7SEpKQkVFBfLy8vDll19i1qxZ19H6zIDi+jKRMkz7KPl7f/3rXwshhLh06ZIAIF588cU2ZY8cOSIABEwK/vWvf12YTCZhNps9y+DOeZubm9umvNVqFbIst1n+4IMPCpVKJUpLSz3L1q1bJwCITz/9tN36++bV/dvf/iYAiB/96Ed+Zbds2SIAiAcffLDN9ikpKaK+vt6zvKmpScTHx4tZs2Z5lv3hD38QAMTBgwfb1IMZXLD7gukX/POf/4QkSXjkkUdQXV3t91q6dCksFotnOneFSZMm+U37rmAwGCBJEgDAbrejtrYW1dXVWLhwIWRZxuHDh7tcz02bNkGlUuG5557zW7548WJMnjwZmzdvhizLfuuWL1+OqKgoz2ej0YhZs2bhwoULnmXK+s2bN6OlpaXL9WMGPuy+YPoFZ86cgRACo0ePbrdM64kpR44cGbCc0+nEyy+/jH/84x8oKCiAaDWPQ11dXZfreenSJaSmpiImJqbNunHjxiE/Px/V1dVITEz0LB86dGibsnFxcaipqfF8vvfee/HWW2/hpZdewu9//3vMmjULCxcuxL333ousrKwu15cZeLAoM/0CIQQkScK2bdvajXYYN26c32ej0Riw3NNPP40//elPuOeee/Cf//mfSExMhFarxdGjR/GTn/ykjSXb03QmekOn0yE3NxeHDh3Cv//9b+zduxc/+9nPsGrVKmzYsAF33HFHL9SU6Q+wKDO9huJSCMSIESOwfft2ZGZmejrcusqbb76JuXPnYuPGjX7LCwoKgqpTIIYOHYrt27ejvr4e0dHRfutOnz6NyMhIxMfHB11nhRkzZmDGjBkAgCtXrmDKlCn46U9/yqI8iGCfMtNrKJEWtbW1bdY99NBDAIDnn3/eL2xNobXroiPUanUbl0VTUxN+//vfB1WnQCxbtgyyLOPll1/2W75t2zYcO3YMS5cuhUoV/GVVXV3dZll6ejoSEhI6XTcmNGBLmek14uLiMHz4cGzcuBHDhg1DUlISwsPDsWTJEkyfPh2rVq3CqlWrMHnyZHzzm99EamoqysrKcOTIEWzduhV2u71Tx/nGN76Bv/71r7jnnnswf/58VFRU4PXXX0dcXFybstOnT4dKpcIvf/lL1NXVITw8HNnZ2Zg5c2bAfT/66KN444038Morr+Dy5cuYO3cuCgoK8Je//AVJSUl46aWXutQ2//Vf/4UdO3bg9ttvR3Z2NoQQ+Pjjj3H27Fn8+Mc/7tI+mQFKn8Z+MCFN65A4IYQ4ePCguPHGG4XRaBQARFZWlt82W7ZsETk5OSImJkaEhYWJ9PR0ceutt4q1a9f6lQMgHnnkkYDHbWpqEj/84Q9FZmam0Ol0Yvjw4WLNmjVi586dbULchBBi/fr1YsyYMUKr1frtN1BInBBCNDY2imeffVZkZ2cLrVYrEhISxIMPPiguX74c8Pxbby+EEI888ojwvfw+/fRTcffdd4usrCyh1+tFTEyMmDFjhvif//mfgOF9TOgiCdHqOY9hGIbpM9inzDAM049gUWYYhulHsCgzDMP0I1iUGYZh+hEsygzDMP0IFmWGYZh+BIsywzBMP4JFmWEYph/BoswwDNOPYFFmGIbpR7AoMwzD9CNYlBmGYfoR/x9eWduozKJmIQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "mean_md = np.mean(L_md, axis=0)\n",
    "std_md = np.std(L_md, axis=0)\n",
    "\n",
    "mean_mld = np.mean(L_mld, axis=0)\n",
    "std_mld = np.std(L_mld, axis=0)\n",
    "\n",
    "fig, ax = plt.subplots(1, figsize=(4, 3))\n",
    "# plt.gcf().subplots_adjust(top=1)\n",
    "\n",
    "# plt.plot(np.array(L_gd), label=\"GD\")\n",
    "ax.plot(mean_md, label=\"MD\")\n",
    "ax.fill_between(list(range(n_epochs)), mean_md - std_md, mean_md + std_md, alpha=0.5)\n",
    "ax.plot(mean_mld, label=\"MLD\")\n",
    "ax.fill_between(list(range(n_epochs)), mean_mld - std_mld, mean_mld + std_mld, alpha=0.5)\n",
    "\n",
    "ax.set_yscale(\"log\")\n",
    "# plt.xscale(\"log\")\n",
    "\n",
    "# ax.set_ylabel(r\"$\\mathcal{F}(\\mu_t)$\", fontsize=13) #, rotation=0)\n",
    "ax.set_xlabel(\"Iterations\", fontsize=13)\n",
    "ax.set_yticks([2.4e1, 2.5e1, 2.6e1, 2.7e1, 2.8e1, 2.9e1])\n",
    "ax.set_yticklabels([24, 25, 26, 27, 28, 29])\n",
    "\n",
    "plt.legend(fontsize=13)\n",
    "plt.grid(True)\n",
    "\n",
    "plt.title(r\"$\\mathcal{F}(\\mu_t)$\", fontsize=13)\n",
    "\n",
    "# plt.savefig(\"./Figures/KL_dirichlet.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "295a39d4",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.7"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
