{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "589d4ad7",
   "metadata": {
    "id": "589d4ad7"
   },
   "source": [
    "# _Diffusion models for Gaussian distributions: Exact solutions and Wasserstein errors_ [ [ 1 ] ](#ref1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b5f348cb",
   "metadata": {
    "id": "b5f348cb"
   },
   "source": [
    "The following code provides figures and table of the article [ [ 1 ] ](#ref1). You can use it with any covariance matrix (provided eigenvalues can be computed). All details are given to extend our analysis to other numerical schemes."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b848ee9",
   "metadata": {
    "id": "3b848ee9"
   },
   "source": [
    "### Reminders of the theory"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4ff05ff0",
   "metadata": {
    "id": "4ff05ff0"
   },
   "source": [
    "We consider the Variance preserving (VP) forward process:\n",
    "\n",
    "\\begin{equation}\n",
    "d\\boldsymbol{x}_t  =-\\beta_t \\boldsymbol{x}_t dt + \\sqrt{2\\beta_t}d\\boldsymbol{w}_t, \\quad 0 \\leq t \\leq T, \\quad  \\boldsymbol{x}_0 \\sim p_\\text{data}. \\tag{1}\n",
    "\\end{equation}\n",
    "\n",
    "Supposing that $p_\\text{data} = \\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma})$, the law of $\\boldsymbol{x}_t$ is $p_t = \\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_t)$ with\n",
    "\\begin{equation}\n",
    "\\boldsymbol{\\Sigma}_t = e^{-2B_t}\\boldsymbol{\\Sigma} + (1-e^{-2B_t})\\boldsymbol{I}\\tag{2}\n",
    "\\end{equation}\n",
    "\n",
    "where $B_t = \\int_0^t \\beta_u$ and consequently the score function verifies $\\nabla \\log p_t(\\boldsymbol{x}) = -\\boldsymbol{\\Sigma}^{-1}_t\\boldsymbol{x}$."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "41401fa7",
   "metadata": {
    "id": "41401fa7"
   },
   "source": [
    "The associated backward SDE is\n",
    "\n",
    "\\begin{equation}\n",
    " d\\tilde{\\boldsymbol{y}}_t = \\beta_{T-t}(\\tilde{\\boldsymbol{y}}_t + 2 \\log p_{T-t}(\\tilde{\\boldsymbol{y}}_t))dt + \\sqrt{2\\beta_{T-t}}d\\boldsymbol{w}_t, \\quad0 \\leq t < T \\tag{3}\n",
    "\\end{equation}\n",
    "\n",
    "and the reverse flow ODE is\n",
    "\n",
    "\\begin{equation}\n",
    " \td\\widehat{\\boldsymbol{y}}_t = \\left[\\beta_{T-t}\\widehat{\\boldsymbol{y}}_t +\\beta_{T-t} \\nabla_{\\widehat{\\boldsymbol{y}}}\\log p_{T-t}(\\widehat{\\boldsymbol{y}}_t)\\right]dt, \\quad 0 \\leq t < T. \\tag{4}\n",
    "\\end{equation}"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9aaac493",
   "metadata": {
    "id": "9aaac493"
   },
   "source": [
    "We study the errors of the diffusion models by studying the Wasserstein-2 distance. For two centered Gaussians $\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_1)$ and $\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_2)$ such that $\\boldsymbol{\\Sigma}_1,\\boldsymbol{\\Sigma}_2$ are simultaneously diagonalizable with respective eigenvalues $(\\lambda_{i,1})_{1\\leq i \\leq d}$ and $(\\lambda_{i,2})_{1\\leq i \\leq d}$,\n",
    "\n",
    "\\begin{equation}\n",
    "\t\\mathbf{W}_2(\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_2),\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_1)) =  \\sqrt{\\sum_{1 \\leq i \\leq d} (\\sqrt{\\lambda_{i,1}}-\\sqrt{\\lambda_{i,2}})^2}. \\tag{5}\n",
    "\\end{equation}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "73d64c2b",
   "metadata": {
    "id": "73d64c2b"
   },
   "outputs": [],
   "source": [
    "def W2(lamb1,lamb2) :\n",
    "    return np.sqrt ( np.sum( (np.sqrt(lamb1)-np.sqrt(lamb2))**2 ) )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e244d4fd",
   "metadata": {
    "id": "e244d4fd"
   },
   "source": [
    "## Packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "lY9GGzds3P9L",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "lY9GGzds3P9L",
    "outputId": "de1e564a-7db4-485b-ca89-d6f0ceb0748a"
   },
   "outputs": [],
   "source": [
    "!pip install scienceplots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "af22a4e6",
   "metadata": {
    "id": "af22a4e6"
   },
   "outputs": [],
   "source": [
    "import pylab as plt\n",
    "import numpy as np\n",
    "import scienceplots\n",
    "plt.style.use('science')\n",
    "from IPython.display import display, Markdown\n",
    "import os\n",
    "plt.rcParams.update(plt.rcParamsDefault)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d0d47fa0",
   "metadata": {},
   "source": [
    "# Load data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e094a09f",
   "metadata": {
    "id": "e094a09f"
   },
   "source": [
    "The Gaussian distribution is known through the eigenvalues of its covariance matrix $\\boldsymbol{\\Sigma}$. ```cifar10.npy``` corresponds to the Gaussian distribution fitted to the CIFAR-10 dataset. This the list of empirical covariance eigenvalues of the normalized images of the dataset. ```ADSN.npy``` corresponds to the ADSN distribution described in the paper."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b6c2ac3c",
   "metadata": {
    "id": "b6c2ac3c"
   },
   "outputs": [],
   "source": [
    "PATH_data ='./'\n",
    "\n",
    "lamb = np.load(PATH_data+'cifar10.npy')\n",
    "# or lamb = np.load(PATH_data+'ADSN.npy')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b802a10b",
   "metadata": {},
   "source": [
    "Bellow, you can choose the outputs path."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2ca0b98a",
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH_output = './'"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0e083bdb",
   "metadata": {
    "id": "0e083bdb"
   },
   "source": [
    "## Parametrization"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4420cc91",
   "metadata": {
    "id": "4420cc91"
   },
   "source": [
    "Let consider $\\beta_t$ linear of the form: $\\beta_t = t \\mapsto \\beta_{\\text{min}} + \\left(\\beta_{\\text{max}}-\\beta_{\\text{min}}\\right)t$ with $\\beta_\\text{min} = 0.05$ and $\\beta_\\text{max} = 10$. The values are from [ [ 2 ] ](#ref2), up to a factor 2 to be consistent with our VP SDE. We introduce also\n",
    "\n",
    "$$B_t = \\int_0^t \\beta_u du = \\beta_{\\text{min}}t + \\left(\\beta_{\\text{max}}-\\beta_{\\text{min}}\\right)\\frac{t^2}{2}.$$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "05b2b44d",
   "metadata": {
    "id": "05b2b44d"
   },
   "outputs": [],
   "source": [
    "T = 1.\n",
    "beta_min = 0.1/2\n",
    "beta_max = 20/2\n",
    "\n",
    "def beta(t) :\n",
    "    return beta_min + t*(beta_max-beta_min)\n",
    "\n",
    "def B(t) :\n",
    "    return beta_min*t +(beta_max-beta_min)*t**2/2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5faf0a10",
   "metadata": {
    "id": "5faf0a10"
   },
   "source": [
    "# Forward process"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4c1adbc5",
   "metadata": {
    "id": "4c1adbc5"
   },
   "source": [
    "$p_t = \\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\Sigma}_t)$ with $\\boldsymbol{\\Sigma}_t = e^{-2B_t}\\boldsymbol{\\Sigma} + (1-e^{-2B_t})\\boldsymbol{I}$. Let consider the eigenvalues of $\\left(\\lambda_i\\right)_{1 \\leq i \\leq d}$ of $\\boldsymbol{\\Sigma}$.  $\\boldsymbol{\\Sigma}_t$ is diagonalizable in the same orthonormal basis and the $i$th eigenvalue of $\\Sigma_t$ is\n",
    "\n",
    "\\begin{equation}\n",
    "\\lambda_i^t = e^{-2B_t}\\lambda_i + (1-e^{-2B_t}). \\tag{6}\n",
    "\\end{equation}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "bbd84604",
   "metadata": {
    "id": "bbd84604"
   },
   "outputs": [],
   "source": [
    "def lamb_Sigma_t(lamb,t) :\n",
    "    ebt = np.exp(-2*B(t))\n",
    "    return ebt*lamb+(1-ebt)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e3a9c203",
   "metadata": {
    "id": "e3a9c203"
   },
   "source": [
    "# Continuous Initialization error"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c0297e89",
   "metadata": {
    "id": "c0297e89"
   },
   "source": [
    "### Continuous SDE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fb9e9954",
   "metadata": {
    "id": "fb9e9954"
   },
   "source": [
    "With an initialization $\\tilde{\\boldsymbol{y}}_0 \\sim \\mathcal{N}(\\boldsymbol{0},\\boldsymbol{I})$, the solution $y_t$ of Equation (3) follows the law $\\tilde{q}_{t} = \\tilde{p}_{T-t}$ where $\\tilde{p}_t$ is the Gaussian distribution $\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\tilde{\\Sigma}}_t)$ and\n",
    "\n",
    "\\begin{equation}\n",
    "\\boldsymbol{\\tilde{\\Sigma}}_t = \\boldsymbol{\\Sigma}_{t}+e^{-2(B_{T}-B_t)}\\boldsymbol{\\Sigma}^2_{t}\\boldsymbol{\\Sigma}_T^{-1}(\\boldsymbol{\\Sigma}^{-1}_T-\\boldsymbol{I}). \\tag{7}\n",
    "\\end{equation}\n",
    "\n",
    "Consequently, $\\boldsymbol{\\tilde{\\Sigma}}_t$ is diagonalizable and we can compute its eigenvalues as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cc615c7e",
   "metadata": {
    "id": "cc615c7e"
   },
   "outputs": [],
   "source": [
    "def lamb_SDE_t(lamb,t) :\n",
    "\n",
    "    lamb_t = lamb_Sigma_t(lamb,t)\n",
    "    lamb_T = lamb_Sigma_t(lamb,T)\n",
    "\n",
    "    return lamb_t+np.exp(-2*(B(T)-B(t)))*lamb_t**2/lamb_T*(1/lamb_T-1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0d167848",
   "metadata": {
    "id": "0d167848"
   },
   "source": [
    "### Continuous ODE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fea36ea2",
   "metadata": {
    "id": "fea36ea2"
   },
   "source": [
    "With an initialization $\\widehat{\\boldsymbol{y}}_0 \\sim \\mathcal{N}(\\boldsymbol{0},\\boldsymbol{I})$, the solution $\\widehat{y}_t$ of Equation (4) follows the law $\\widehat{q}_{t} = \\widehat{p}_{T-t}$ where $\\widehat{p}_t$ is the Gaussian distribution $\\mathcal{N}(\\boldsymbol{0},\\boldsymbol{\\widehat{\\Sigma}}_t)$ and\n",
    "\n",
    "\\begin{equation}\n",
    "\\boldsymbol{\\widehat{\\Sigma}}_t = \\boldsymbol{\\Sigma}^{-1}_T\\boldsymbol{\\Sigma}_{t}. \\tag{8}\n",
    "\\end{equation}\n",
    "\n",
    "Consequently, $\\boldsymbol{\\tilde{\\Sigma}}_t$ is diagonalizable and we can compute its eigenvalues as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cc58b123",
   "metadata": {
    "id": "cc58b123"
   },
   "outputs": [],
   "source": [
    "def lamb_ODE_t(lamb,t) :\n",
    "\n",
    "    lamb_t = lamb_Sigma_t(lamb,t)\n",
    "    lamb_T = lamb_Sigma_t(lamb,T)\n",
    "\n",
    "\n",
    "    return lamb_t/lamb_T"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc3ff10f",
   "metadata": {
    "id": "cc3ff10f"
   },
   "source": [
    "# Discretization of the equations"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "84f973a6",
   "metadata": {
    "id": "84f973a6"
   },
   "source": [
    "## Discretization of the bacward SDE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c2e0039",
   "metadata": {
    "id": "3c2e0039"
   },
   "source": [
    "Under Gaussian assumption, Equation (3) becomes:\n",
    "\n",
    "\\begin{equation}\n",
    " d\\tilde{\\boldsymbol{y}}_t = \\beta_{T-t}(\\tilde{\\boldsymbol{y}}_t - 2\\boldsymbol{\\Sigma}^{-1}_{T-t}(\\tilde{\\boldsymbol{y}}_t))dt + \\sqrt{2\\beta_{T-t}}d\\boldsymbol{w}_t, \\quad0 \\leq t < T. \\tag{9}\n",
    "\\end{equation}\n",
    "\n",
    "We study the Euler-Maruyama's scheme (EM) and the Exponential Integrator scheme (EI)."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f27d20ae",
   "metadata": {
    "id": "f27d20ae"
   },
   "source": [
    "### Euler Maruyama's scheme"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "588765c1",
   "metadata": {
    "id": "588765c1"
   },
   "source": [
    "The EM discretization of Equation (9) is\n",
    "\\begin{equation}\n",
    "\\boldsymbol{y}^{\\text{EM},k+1} = \\boldsymbol{y}^{\\text{EM},k} + \\Delta_t \\beta_{T-t_k}\\left(\\boldsymbol{y}_{k}-2\\Sigma_{T-t_k}^{-1}\\boldsymbol{y}^{\\text{EM},k}\\right)+ \\sqrt{2\\Delta_t \\beta_{T-t_k}}\\boldsymbol{z}_k, \\quad \\boldsymbol{z}_k \\sim \\mathcal{N}_0. \\tag{10}\n",
    "\\end{equation}\n",
    "\n",
    "Consequently, the $i$th eigenvalue $\\lambda_i^{EM,k}$ of the covariance matrix of $\\left(\\boldsymbol{y}^{k,\\text{EM}}\\right)_{0 \\leq k \\leq N-1}$ verifies\n",
    "\n",
    "\\begin{equation}\n",
    "\\lambda_i^{\\text{EM},k+1} = \\left(1+\\Delta_t \\beta_{T-t_k}\\left(1-\\tfrac{2}{\\lambda_i^{T-t_k}}\\right)\\right)^2\\lambda_i^{\\text{EM},k} + 2\\Delta_t \\beta_{T-t_k} \\tag{11}\n",
    "\\end{equation}\n",
    "\n",
    "with $\\lambda_i^{t}$ $i$th eigenvalue of $\\boldsymbol{\\Sigma}_t$ and $\\lambda_i^{\\text{EM},0}$ initialized at $1$ or $\\lambda_i^{T}$ depending on the choice of initialization. The following compute the Wasserstein error at each step."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ee7dc5e5",
   "metadata": {
    "id": "ee7dc5e5"
   },
   "outputs": [],
   "source": [
    "def W2_EM(N,lamb,t_eps=0,p_T = False,all_t = True) :\n",
    "\n",
    "    tk = np.array([(T-t_eps)*k/(N-1) for k in range(N)])\n",
    "    Delta_t = tk[1]-tk[0]\n",
    "\n",
    "    #Initialization at p_T\n",
    "    if p_T :\n",
    "        lamb_EM = lamb_Sigma_t(lamb,T)\n",
    "    #Initialization at N_0\n",
    "    else :\n",
    "        lamb_EM = np.ones_like(lamb)\n",
    "\n",
    "    if all_t :\n",
    "        W2_EM_list = [W2(lamb_EM,lamb_Sigma_t(lamb,T))]\n",
    "\n",
    "    for k in range(N-1) :\n",
    "        lamb_T_tk = lamb_Sigma_t(lamb,T-tk[k])\n",
    "        beta_T_tk = beta(T-tk[k])\n",
    "\n",
    "        lamb_EM =  (1+Delta_t*beta_T_tk*(1-2/lamb_T_tk))**2*lamb_EM + 2*Delta_t*beta_T_tk\n",
    "\n",
    "        if all_t :\n",
    "            W2_EM_list.append(W2(lamb_EM,lamb_Sigma_t(lamb,T-tk[k+1])))\n",
    "\n",
    "    if all_t :\n",
    "        W2_EM_list.reverse()\n",
    "        return W2_EM_list\n",
    "\n",
    "    else :\n",
    "        return W2(lamb_EM,lamb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a63e142",
   "metadata": {
    "id": "2a63e142"
   },
   "source": [
    "### Exponential Integrator (EI) scheme"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4a7809db",
   "metadata": {
    "id": "4a7809db"
   },
   "source": [
    "The EI discretization of Equation (9) is\n",
    "\\begin{equation}\n",
    "\\boldsymbol{y}^{\\text{EI},k+1} = \\boldsymbol{y}^{\\text{EI},k} + \\gamma_{1,k}\\left(\\boldsymbol{y}^{\\text{EI},k+1}-2\\Sigma_{T-t_k}^{-1}\\boldsymbol{y}^{\\text{EI},k}\\right)+ \\sqrt{2\\gamma_{2,k}}\\boldsymbol{z}_k \\quad \\boldsymbol{z}_k\\sim \\mathcal{N}_0 \\tag{12}\n",
    "\\end{equation}\n",
    "\n",
    "with\n",
    "$\\gamma_{1,k}  = \\exp\\left(B_{T-t_{k}}-B_{T-t_{k+1}}\\right)-1$ and $\\gamma_{2,k}  = \\frac{1}{2}\\left[\\exp\\left(2\\left(B_{T-t_{k}}-B_{T-t_{k+1}}\\right)\\right)-1\\right]$.\n",
    "\n",
    "Consequently, the $i$th eigenvalue $\\lambda_i^{\\text{EI},k}$ of the covariance matrix of $\\left(\\boldsymbol{y}^{k,\\text{EI}}\\right)_{0 \\leq k \\leq N-1}$ verifies\n",
    "\n",
    "\\begin{equation}\n",
    "\\lambda_i^{\\text{EI},k+1} = \\left(1+\\gamma_{1,k}\\left(1-\\tfrac{2}{\\lambda_i^{T-t_k}}\\right)\\right)^2\\lambda_i^{\\text{EI},k}+ 2\\gamma_{2,k} \\tag{13}\n",
    "\\end{equation}\n",
    "\n",
    "with $\\lambda_i^{t}$ $i$th eigenvalue of $\\boldsymbol{\\Sigma}_t$ and $\\lambda_i^{\\text{EI},0}$ initialized at $1$ or $\\lambda_i^{T}$ depending on the choice of initialization. The following compute the Wasserstein error at each step.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "7c503424",
   "metadata": {
    "id": "7c503424"
   },
   "outputs": [],
   "source": [
    "def W2_EI(N,lamb,t_eps=0,p_T = False,all_t = True) :\n",
    "\n",
    "    tk = np.array([(T-t_eps)*k/(N-1) for k in range(N)])\n",
    "    Delta_t = tk[1]-tk[0]\n",
    "\n",
    "    #Initialization at p_T\n",
    "    if p_T :\n",
    "        lamb_EI = lamb_Sigma_t(lamb,T)\n",
    "    #Initialization at N_0\n",
    "    else :\n",
    "        lamb_EI = np.ones_like(lamb)\n",
    "\n",
    "    if all_t :\n",
    "        W2_EI_list = [W2(lamb_EI,lamb_Sigma_t(lamb,T))]\n",
    "\n",
    "    for k in range(N-1) :\n",
    "        gamma_1_k = np.exp(B(T-tk[k])-B(T-tk[k+1]))-1\n",
    "        gamma_2_k = (np.exp(2*(B(T-tk[k])-B(T-tk[k+1])))-1)/2\n",
    "\n",
    "        lamb_T_tk =  lamb_Sigma_t(lamb,T-tk[k])\n",
    "\n",
    "        beta_T_tk = beta(T-tk[k])\n",
    "\n",
    "\n",
    "        lamb_EI = (1+gamma_1_k*(1-2/lamb_T_tk))**2*lamb_EI + 2*gamma_2_k\n",
    "\n",
    "        if all_t :\n",
    "\n",
    "            W2_EI_list.append(W2(lamb_EI,lamb_Sigma_t(lamb,T-tk[k+1])))\n",
    "\n",
    "    if all_t :\n",
    "        W2_EI_list.reverse()\n",
    "\n",
    "        return W2_EI_list\n",
    "\n",
    "    else :\n",
    "\n",
    "        return W2(lamb_EI,lamb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cd1a21f5",
   "metadata": {
    "id": "cd1a21f5"
   },
   "source": [
    "## Discretization of the flow ODE"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9526c73f",
   "metadata": {
    "id": "9526c73f"
   },
   "source": [
    "Under Gaussian assumption, Equation (4) becomes\n",
    "\n",
    "\\begin{equation}\n",
    " \td\\widehat{\\boldsymbol{y}}_t = \\left[\\beta_{T-t}\\widehat{\\boldsymbol{y}}_t -\\beta_{T-t} \\boldsymbol{\\Sigma}^{-1}_{T-t}(\\widehat{\\boldsymbol{y}}_t)\\right]dt, \\quad 0 \\leq t < T. \\tag{14}\n",
    "\\end{equation}\n",
    "\n",
    "We study the Euler scheme and the Heun's scheme."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc47120e",
   "metadata": {
    "id": "cc47120e"
   },
   "source": [
    "## Euler scheme"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "399bc3f0",
   "metadata": {
    "id": "399bc3f0"
   },
   "source": [
    "The EM discretization of Equation (14) is\n",
    "\n",
    "\\begin{equation}\n",
    "\\boldsymbol{y}^{\\text{Euler},k+1} = \\boldsymbol{y}^{\\text{Euler},k}+\\Delta_t\\beta_{T-t_k}\\left(\\boldsymbol{y}^{\\text{Euler},k}-\\Sigma^{-1}_{T-t_k}\\boldsymbol{y}^{\\text{Euler},k}\\right). \\tag{15}\n",
    "\\end{equation}\n",
    "\n",
    "Consequently, the $i$th eigenvalue $\\lambda_i^{Euler,k}$ of the covariance matrix of $\\left(\\boldsymbol{y}^{k,\\text{Euler}}\\right)_{0 \\leq k \\leq N-1}$ verifies\n",
    "\n",
    "\\begin{equation}\n",
    "\\lambda_i^{\\text{Euler},k+1} =\\left(1+\\Delta_t\\beta_{T-t_k}\\left(1-\\tfrac{1}{\\lambda_i^{T-t_k}}\\right)\\right)^2\\lambda_i^{\\text{Euler},k} \\tag{16}\n",
    "\\end{equation}\n",
    "\n",
    "with $\\lambda_i^{t}$ $i$th eigenvalue of $\\boldsymbol{\\Sigma}_t$ and $\\lambda_i^{\\text{Euler},0}$ initialized at $1$ or $\\lambda_i^{T}$ depending on the choice of initialization. The following compute the Wasserstein error at each step."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6f8fe791",
   "metadata": {
    "id": "6f8fe791"
   },
   "outputs": [],
   "source": [
    "def W2_Euler(N,lamb,t_eps=0,p_T = False,all_t = True) :\n",
    "\n",
    "    tk = np.array([(T-t_eps)*k/(N-1) for k in range(N)])\n",
    "    Delta_t = tk[1]-tk[0]\n",
    "\n",
    "    #Initialization at p_T\n",
    "    if p_T :\n",
    "        lamb_Euler = lamb_Sigma_t(lamb,T)\n",
    "    #Initialization at N_0\n",
    "    else :\n",
    "        lamb_Euler = np.ones_like(lamb)\n",
    "\n",
    "    if all_t :\n",
    "        W2_Euler_list = [W2(lamb_Euler,lamb_Sigma_t(lamb,T))]\n",
    "\n",
    "    for k in range(N-1) :\n",
    "        lamb_T_tk =  lamb_Sigma_t(lamb,T-tk[k])\n",
    "        beta_T_tk = beta(T-tk[k])\n",
    "\n",
    "        lamb_Euler = (1+Delta_t*beta_T_tk*(1-1/lamb_T_tk))**2*lamb_Euler\n",
    "\n",
    "        if all_t :\n",
    "            W2_Euler_list.append(W2(lamb_Euler,lamb_Sigma_t(lamb,T-tk[k+1])))\n",
    "\n",
    "    if all_t :\n",
    "        W2_Euler_list.reverse()\n",
    "\n",
    "        return W2_Euler_list\n",
    "\n",
    "    else :\n",
    "\n",
    "        return W2(lamb_Euler,lamb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "52c4dee4",
   "metadata": {
    "id": "52c4dee4"
   },
   "source": [
    "## Heun's scheme"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8a4ba547",
   "metadata": {
    "id": "8a4ba547"
   },
   "source": [
    "The EM discretization of Equation (14) is\n",
    "\n",
    "\\begin{align}\n",
    "\\tag{17}\n",
    "        y^{k+1/2,\\text{Heun}} & = y^{k,\\text{Heun}}+ \\Delta_t \\beta_{T-t_k}\\left(y^{k,\\text{Heun}}-\\boldsymbol{\\Sigma}_{T-t_k}^{-1}y^{k,\\text{Heun}}\\right) \\quad \\quad \\\\\n",
    "        y^{k+1,\\text{Heun}} & = y^{k,\\text{Heun}}+ \\frac{\\Delta_t}{2} \\beta_{T-t_k}\\left(y^{k,\\text{Heun}}-\\boldsymbol{\\Sigma}_{T-t_k}^{-1}y^{k,\\text{Heun}}\\right)+ \\frac{\\Delta_t}{2} \\beta_{T-t_{k+1}}\\left(y^{k+1/2,\\text{Heun}}-\\boldsymbol{\\Sigma}_{T-t_{k+1}}^{-1}y^{k+1/2,\\text{Heun}}\\right).\n",
    "\\end{align}\n",
    "\n",
    "\n",
    "Consequently, the $i$th eigenvalue $\\lambda_i^{\\text{Heun},k}$ of the covariance matrix of $\\left(y^{k,\\text{Heun}}\\right)_{0 \\leq k \\leq N-1}$ verifies\n",
    "\n",
    "$$\n",
    " \\lambda_i^{k+1,\\text{Heun}}  = \\left(1+ \\frac{\\Delta_t}{2} \\beta_{T-t_k}\\left(1-\\tfrac{1}{\\lambda_i^{T-t_k}}\\right)+\\frac{\\Delta_t}{2} \\beta_{T-t_{k+1}}\\left(1-\\tfrac{1}{\\lambda_i^{T-t_{k+1}}}\\right)\\left( 1+ \\Delta_t \\beta_{T-t_k}\\left(1-\\tfrac{1}{\\lambda_i^{T-t_k}}\\right)\\right)\\right)^2\\lambda_i^{k,\\text{Heun}} \\tag{18}\n",
    "$$\n",
    "\n",
    "with $\\lambda_i^{t}$ $i$th eigenvalue of $\\boldsymbol{\\Sigma}_t$. With $\\lambda_i^{\\text{Heun},0}$ initialized at $1$ or $\\lambda_i^{T}$ depending on the choice of initialization."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "f9575d1d",
   "metadata": {
    "id": "f9575d1d"
   },
   "outputs": [],
   "source": [
    "def W2_Heun(N,lamb,t_eps=0,p_T = False,all_t = True) :\n",
    "    tk = np.array([(T-t_eps)*k/(N-1) for k in range(N)])\n",
    "    Delta_t = tk[1]-tk[0]\n",
    "\n",
    "    #Initialization at p_T\n",
    "    if p_T :\n",
    "        lamb_Heun = lamb_Sigma_t(lamb,T)\n",
    "    #Initialization at N_0\n",
    "    else :\n",
    "        lamb_Heun = np.ones_like(lamb)\n",
    "\n",
    "    if all_t :\n",
    "        W2_Heun_list = [W2(lamb_Heun,lamb_Sigma_t(lamb,T))]\n",
    "\n",
    "    for k in range(N-1) :\n",
    "        lamb_T_tk =  lamb_Sigma_t(lamb,T-tk[k])\n",
    "        beta_T_tk = beta(T-tk[k])\n",
    "\n",
    "        lamb_T_tk_1 =  lamb_Sigma_t(lamb,T-tk[k+1])\n",
    "        beta_T_tk_1 = beta(T-tk[k+1])\n",
    "\n",
    "\n",
    "        lamb_Heun =(1+ Delta_t/2*beta_T_tk*(1-1/lamb_T_tk)+Delta_t/2*beta_T_tk_1*(1-1/lamb_T_tk_1)*(1+Delta_t*beta_T_tk*(1-1/lamb_T_tk)))**2*lamb_Heun\n",
    "\n",
    "        if all_t :\n",
    "            W2_Heun_list.append(W2(lamb_Heun,lamb_T_tk_1 ))\n",
    "\n",
    "    if all_t :\n",
    "        W2_Heun_list.reverse()\n",
    "\n",
    "        return W2_Heun_list\n",
    "\n",
    "    else :\n",
    "\n",
    "        return W2(lamb_Heun,lamb)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0632ee57",
   "metadata": {
    "id": "0632ee57"
   },
   "source": [
    "# Error graphs"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ee4cbb6",
   "metadata": {
    "id": "5ee4cbb6"
   },
   "source": [
    "Bellow, the code to plot the Figure 1 of [ [ 1 ] ](#ref1) showing the Wasserstein value of the discretization, the initialization along the time and the truncation error."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2fe2bf20",
   "metadata": {
    "id": "2fe2bf20"
   },
   "source": [
    "### Discretization and initialization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "940e1ac0",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 450
    },
    "id": "940e1ac0",
    "outputId": "0f4774a1-a608-483f-9284-39a7329ec9af"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/59/32mlzt9101s96_s3bpqbffvr0000gp/T/ipykernel_38314/1759821661.py:23: RuntimeWarning: divide by zero encountered in divide\n",
      "  lamb_Heun =(1+ Delta_t/2*beta_T_tk*(1-1/lamb_T_tk)+Delta_t/2*beta_T_tk_1*(1-1/lamb_T_tk_1)*(1+Delta_t*beta_T_tk*(1-1/lamb_T_tk)))**2*lamb_Heun\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "T = 1\n",
    "N = 1000\n",
    "tk = np.array([T*k/(N-1) for k in range(N)])\n",
    "\n",
    "\n",
    "W2_SDE = [W2(lamb_SDE_t(lamb,T-t),lamb_Sigma_t(lamb,T-t)) for t in tk]\n",
    "W2_SDE.reverse()\n",
    "W2_ODE = [W2(lamb_ODE_t(lamb,T-t),lamb_Sigma_t(lamb,T-t)) for t in tk]\n",
    "W2_ODE.reverse()\n",
    "\n",
    "plt.semilogy(tk,W2_SDE,'-',label='SDE',color='tab:purple')\n",
    "plt.semilogy(tk,W2_ODE,'-',label='ODE',color='k')\n",
    "\n",
    "das = (3,2)\n",
    "plt.semilogy(tk,W2_EM(N,lamb),'--',label='EM',dashes=das,color='C0')\n",
    "plt.semilogy(tk,W2_EI(N,lamb),'--',label='EI',dashes=das,color='tab:green')\n",
    "plt.semilogy(tk,W2_Euler(N,lamb),'--',label='Euler',dashes=das,color='tab:orange')\n",
    "plt.semilogy(tk,W2_Heun(N,lamb),'--',label='Heun',dashes=das,color='tab:red')\n",
    "\n",
    "\n",
    "\n",
    "plt.ylabel('$\\mathbf{W}_2(\\cdot,p_t)$')\n",
    "axes = plt.gca()\n",
    "axes.xaxis.set_ticks([0,0.2,0.4,0.6,0.8,1.0])\n",
    "axes.xaxis.set_ticklabels([\"0\",\"0.2\",\"0.4\",\"0.6\",\"0.8\",r\"$\\mathrm{T} = 1$\"])\n",
    "\n",
    "plt.xlabel('Time $t$')\n",
    "\n",
    "\n",
    "plt.legend( ncol=3,fontsize='x-small')\n",
    "\n",
    "plt.show()\n",
    "\n",
    "plt.savefig(PATH_output+'discretization_initialization_error.pdf', bbox_inches='tight', dpi=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c1b56f9",
   "metadata": {
    "id": "1c1b56f9"
   },
   "source": [
    "### Truncation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "1633f266",
   "metadata": {
    "id": "1633f266"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/59/32mlzt9101s96_s3bpqbffvr0000gp/T/ipykernel_38314/1759821661.py:23: RuntimeWarning: divide by zero encountered in divide\n",
      "  lamb_Heun =(1+ Delta_t/2*beta_T_tk*(1-1/lamb_T_tk)+Delta_t/2*beta_T_tk_1*(1-1/lamb_T_tk_1)*(1+Delta_t*beta_T_tk*(1-1/lamb_T_tk)))**2*lamb_Heun\n"
     ]
    }
   ],
   "source": [
    "eps_list_graph = [0,10**-5,10**-4,10**-3,10**-2]\n",
    "\n",
    "W2_eps_EM = []\n",
    "W2_eps_EI = []\n",
    "W2_eps_Euler = []\n",
    "W2_eps_Heun = []\n",
    "W2_eps_SDE = []\n",
    "W2_eps_ODE = []\n",
    "\n",
    "N = 1000\n",
    "\n",
    "eps_list_graph = [0,10**-5,10**-4,10**-3,10**-2]\n",
    "for t_eps in eps_list_graph :\n",
    "    W2_eps_EM.append(W2_EM(N,lamb,t_eps,all_t=False))\n",
    "    W2_eps_EI.append(W2_EI(N,lamb,t_eps,all_t=False))\n",
    "    W2_eps_Euler.append(W2_Euler(N,lamb,t_eps,all_t=False))\n",
    "    W2_eps_Heun.append(W2_Heun(N,lamb,t_eps,all_t=False))\n",
    "    W2_eps_SDE.append(W2(lamb_SDE_t(lamb,t_eps),lamb_Sigma_t(lamb,0)))\n",
    "    W2_eps_ODE.append(W2(lamb_ODE_t(lamb,t_eps),lamb_Sigma_t(lamb,0)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "21f4d042",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 467
    },
    "id": "21f4d042",
    "outputId": "feb30738-cabc-4021-c28f-cad74a6db06c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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QvvT0tLw8PC44cCqGpn5WghRVopFYesvx/n1o73kZJjxqefKHc90kqRIiCqozE1pWq01pzIajYwaNYq2bdtisVj49ttvee6557jzzjvLNdCqQprShBClkZWax6ovozh3NBWAFr2C6DlGms6EqGwl/fwuc2J04cIF9uzZw759+9i7dy979+7l6NGjaDQamjdvTqtWrWjdujWtW7fmpptuKvONVDWSGAkhSio2Kol/FkXbms763dWMxp387R2WELVShSdGxcnNzWX//v3s3bvXljAdOHCA1NTU8rqE3UliJIS4HsWisP23GHb9dQoA32BXhtzbEk9/ZztHJkTtVWkTPF7O0dGRTp06ST8cIUStlZmSy6ovo4g7lgZAyz516XF7I/QGaToTojoo18RICCFqs1MHkvjnq2hys8wYHC82nXWUpjMhqhNJjIQQ4gYpFoVtv8aw++/Lms7ua4lnHWk6E6K6kcRICCFuQEZyLpFfRhF33Np01qpPXbpL05kQ1VaZ5zG65km1Wvr378+uXbsq4vRCCFElnNyfyNJXdhB3PA2jo44h97Wk951NJSkSohqrkBqjhQsXcurUKWbMmMGmTZsq4hJCCGE3FovCtp9PsCfSOsGtX4gbQ+5rgYefNJ0JUd2V63D92kCG6wtRu2Uk57LqiwPEn0gHoFW/evQY1QidoUIq4IUQ5cQuw/WFEKImO/lfIv98HU1eVj5GJz39725Gw3Z17B2WEKIc3XBi1L17d44fP8758+fLIx4hhKhyLBaFrT+fYO/FprM6oW4Mua8l7r5Odo5MCFHebjgxGjt2LImJieURS5UWERFBREQEFovF3qEIISpRelIOq76I4nyMtemsTf9guo1qiE4vTWdC1ETSx6iUpI+RELVHzL4EVn99kLzsfByc9fS/uzkN2vrZOywhRBlUSB+j2NhYQkJCSlz+7Nmz1K1btzSXEEKISrX9txNotBo63VLfts+Sr7Dl5+Ps++c0AHXC3BlybwtpOhOiFihVXXCnTp2477772L59+1XLpKWl8fnnn9OyZUuWL19+wwEKIURF0mg1bP8thh1/xACQnpjD8rd325KigAbujHq8vSRFQtQSpaoxOnjwIK+++io33XQTBoOBjh07EhQUhKOjIykpKURHRxMVFUXHjh156623GDp0aEXFLYQQ5aKgpmj7bzGkxGcRG5VMXnY+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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "\n",
    "T_eps_plot = [10**-6,10**-5,10**-4,10**-3,10**-2]\n",
    "#The 'zero eps' is plotted at 10**-6 to enable the loglog setting\n",
    "\n",
    "plt.loglog(T_eps_plot,W2_eps_SDE,'-x',label='SDE',color='tab:purple')\n",
    "plt.loglog(T_eps_plot,W2_eps_ODE,'-x',label='ODE',color='k')\n",
    "das = (3,2)\n",
    "plt.loglog(T_eps_plot,W2_eps_EM,'--x',label='EM',dashes=das,color='C0')\n",
    "plt.loglog(T_eps_plot,W2_eps_EI,'--x',label='EI',dashes=das,color='tab:green')\n",
    "plt.loglog(T_eps_plot,W2_eps_Euler,'--x',label='Euler',dashes=das,color='tab:orange')\n",
    "plt.loglog(T_eps_plot,W2_eps_Heun,'--x',label='Heun',dashes=das,color='tab:red')\n",
    "\n",
    "#plt.legend()\n",
    "axes = plt.gca()\n",
    "axes.xaxis.set_ticks(T_eps_plot)\n",
    "axes.xaxis.set_ticklabels([str(t_eps) for t_eps in eps_list_graph])\n",
    "plt.ylabel('$\\mathbf{W}_2(\\cdot,p_0)$')\n",
    "\n",
    "plt.xlabel(r'Truncation time $\\varepsilon$')\n",
    "\n",
    "\n",
    "plt.legend(ncol=3,fontsize='x-small')\n",
    "\n",
    "plt.show()\n",
    "\n",
    "plt.savefig(PATH_output+'truncation_error.pdf', bbox_inches='tight', dpi=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cf59f897",
   "metadata": {
    "id": "cf59f897"
   },
   "source": [
    "## Two graphs with the same scale"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "cc983784",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 406
    },
    "id": "cc983784",
    "outputId": "e45d0576-866f-46d3-887f-2311b90aa8e0"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/59/32mlzt9101s96_s3bpqbffvr0000gp/T/ipykernel_38314/1759821661.py:23: RuntimeWarning: divide by zero encountered in divide\n",
      "  lamb_Heun =(1+ Delta_t/2*beta_T_tk*(1-1/lamb_T_tk)+Delta_t/2*beta_T_tk_1*(1-1/lamb_T_tk_1)*(1+Delta_t*beta_T_tk*(1-1/lamb_T_tk)))**2*lamb_Heun\n"
     ]
    },
    {
     "data": {
      "image/png": "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iXaomRBFM1qMDFpyNxcyT6NTFB6PV/NE5mW2+MHADj34n68XJrWa7dWbMmLxPNx9ne1dZaASjnTdiNFoZNeuXfTu3bvA8d69e7N582YAWrduzYEDB7hw4QLp6eksX76cPn36XPec7733Hh4eHrk/ISEhZfoehKioVq1ahaenJyNGjADA3d2d9957j+nTpxcop9FomDJlCnFxcezZs8ceVRV2cPz4cXr16kVkZCR9+vTh8uXLQMG7+PPmzePll18GoGvXrrz00ktERkYSERHBmTNn7Fb3slQW/RKUbt+k0Wh44403mDp1aoHjU6dO5Y033kCj0dzSeStjm6FWqYmKjmLO3jkFjs/ZO4eo6CjUqir1tclGoybhs89tAVY+8bNmkfDZ56Ap/fcs7YW4HUkZVs6cDyYiU83iM1k8lXkGPWZi//uG4ykJfJBuJWb4czy8+pcKE3BBJRzpupGEhAQsFgsBAQUzjgQEBHDp0iUAtFot06dPp1u3blitVl588UV8fHyue85XXnmFSZMm5T5OS0uTwEvYnaIoZGVllfp5nZ2drzut6dChQzRv3rzAsebNm3P48GF69epV4LharaZp06YcO3aM5s2bk5iYSERERO7zX3/9NS1btizVumeZiv48HDQOaNR5XxqNFiNmq7lQOY1ag4PGodjXK4/3dDPW6/wOqBwcUOX7omw1GsFc+D2j0aB2uPX3fPHiRT744AMAJkyYwNdff02NGjVYsGABU6dOve50u6tcXV3ZtWsX06dP58svv+Tdd98tdl0qi7Lol6BkfdPN2otJkyZhNBp54403MBqNvPzyy7z//vtMmzaN1157jUmTJpGZmVnodTdqL6Bythmjw0ajKApR0VEAjGs2jqg9UczZN4fHmzzO6LDRua+rbG3G9doL3yeeALAFWIDPo4+SMHs2ibPn4PPkOHzGjrW9VtoLYScmi4mknCQCXGztaDV9DvPUqbSJO405W83FJAee2ZzMokNmejS/mw+++pQGkUE3OWv5q1JB11XXdgKKohQ4NmjQIAYNGlSsczk4OOBQgkZGiPKQlZWFq6trqZ83IyMDF5fiLzK90Reu/OtUymNaTZufip6O9W2fb2lVrVXu4w93fMiCowsKletVoxefdP2k2NerCFOFjraILPJ46P/+h0ub1rmP495/n+Sffi5Uzq1PH4I/nVns6137nq/e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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10,4))\n",
    "plt.subplot(1,2,1)\n",
    "plt.semilogy(tk,W2_SDE,'-',label='SDE',color='tab:purple')\n",
    "plt.semilogy(tk,W2_ODE,'-',label='ODE',color='k')\n",
    "\n",
    "das = (3,2)\n",
    "plt.semilogy(tk,W2_EM(N,lamb),'--',label='EM',dashes=das,color='C0')\n",
    "plt.semilogy(tk,W2_EI(N,lamb),'--',label='EI',dashes=das,color='tab:green')\n",
    "plt.semilogy(tk,W2_Euler(N,lamb),'--',label='Euler',dashes=das,color='tab:orange')\n",
    "plt.semilogy(tk,W2_Heun(N,lamb),'--',label='Heun',dashes=das,color='tab:red')\n",
    "\n",
    "\n",
    "plt.ylabel('$\\mathbf{W}_2(\\cdot,p_t)$')\n",
    "axes = plt.gca()\n",
    "axes.xaxis.set_ticks([0,0.2,0.4,0.6,0.8,1.0])\n",
    "axes.xaxis.set_ticklabels([\"0\",\"0.2\",\"0.4\",\"0.6\",\"0.8\",r\"$\\mathrm{T} = 1$\"])\n",
    "\n",
    "plt.xlabel('Time $t$')\n",
    "\n",
    "\n",
    "plt.legend( ncol=3,fontsize='x-small')\n",
    "\n",
    "plt.subplot(1,2,2,sharey=axes)\n",
    "\n",
    "T_eps_plot = [10**-6,10**-5,10**-4,10**-3,10**-2]\n",
    "\n",
    "\n",
    "plt.loglog(T_eps_plot,W2_eps_SDE,'-x',label='SDE',color='tab:purple')\n",
    "plt.loglog(T_eps_plot,W2_eps_ODE,'-x',label='ODE',color='k')\n",
    "das = (3,2)\n",
    "plt.loglog(T_eps_plot,W2_eps_EM,'--x',label='EM',dashes=das,color='C0')\n",
    "plt.loglog(T_eps_plot,W2_eps_EI,'--x',label='EI',dashes=das,color='tab:green')\n",
    "plt.loglog(T_eps_plot,W2_eps_Euler,'--x',label='Euler',dashes=das,color='tab:orange')\n",
    "plt.loglog(T_eps_plot,W2_eps_Heun,'--x',label='Heun',dashes=das,color='tab:red')\n",
    "\n",
    "axes = plt.gca()\n",
    "axes.xaxis.set_ticks(T_eps_plot)\n",
    "axes.xaxis.set_ticklabels([str(t_eps) for t_eps in eps_list_graph])\n",
    "plt.ylabel('$\\mathbf{W}_2(\\cdot,p_0)$')\n",
    "\n",
    "plt.xlabel(r'Truncation time $\\varepsilon$')\n",
    "\n",
    "plt.legend(ncol=3,fontsize='x-small')\n",
    "\n",
    "plt.show()\n",
    "\n",
    "plt.savefig(PATH_output+'truncation_discretization_initialization.pdf', bbox_inches='tight', dpi=100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dc74a85b",
   "metadata": {
    "id": "dc74a85b"
   },
   "source": [
    "# Ablation study table"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72da9e33",
   "metadata": {
    "id": "72da9e33"
   },
   "source": [
    "The following code displays the table corresponding to Table 2 of [ [ 1 ] ](#ref1)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "32829f90",
   "metadata": {
    "id": "32829f90"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/59/32mlzt9101s96_s3bpqbffvr0000gp/T/ipykernel_38314/1759821661.py:23: RuntimeWarning: divide by zero encountered in divide\n",
      "  lamb_Heun =(1+ Delta_t/2*beta_T_tk*(1-1/lamb_T_tk)+Delta_t/2*beta_T_tk_1*(1-1/lamb_T_tk_1)*(1+Delta_t*beta_T_tk*(1-1/lamb_T_tk)))**2*lamb_Heun\n"
     ]
    }
   ],
   "source": [
    "N_list = [50,250,500,1000] #500\n",
    "eps_list = [0., 10**-5,10**-4,10**-3]\n",
    "P_T = [True,False]\n",
    "schemes_list = ['EM','EI','Euler','Heun']\n",
    "\n",
    "\n",
    "W2_dict = {scheme: {str(p_T):{} for p_T in P_T } for scheme in schemes_list}\n",
    "W2_dict['SDE'] =  {str(p_T):{} for p_T in P_T }\n",
    "W2_dict['ODE'] = {str(p_T):{} for p_T in P_T }\n",
    "#Continuous integration\n",
    "\n",
    "\n",
    "for scheme in ['SDE','ODE'] :\n",
    "    if scheme == 'SDE' :\n",
    "        lamb_funct = lamb_SDE_t\n",
    "    elif scheme == 'ODE' :\n",
    "        lamb_funct = lamb_ODE_t\n",
    "    for t_eps in eps_list :\n",
    "        W2_dict[scheme]['False'][str(t_eps)] = W2(lamb_funct(lamb,t_eps),lamb_Sigma_t(lamb,0))\n",
    "        W2_dict[scheme]['True'][str(t_eps)] = W2(lamb_Sigma_t(lamb,t_eps),lamb_Sigma_t(lamb,0))\n",
    "\n",
    "\n",
    "for scheme in schemes_list :\n",
    "\n",
    "    if scheme == 'EM' :\n",
    "            W2_funct = W2_EM\n",
    "    elif scheme == 'EI' :\n",
    "            W2_funct = W2_EI\n",
    "    elif scheme == 'Euler' :\n",
    "            W2_funct = W2_Euler\n",
    "    elif scheme == 'Heun' :\n",
    "            W2_funct = W2_Heun\n",
    "    for p_T in P_T :\n",
    "        for N in N_list :\n",
    "            W2_dict[scheme][str(p_T)][str(N)] = {}\n",
    "            for t_eps in eps_list :\n",
    "                W2_dict[scheme][str(p_T)][str(N)][str(t_eps)] = W2_funct(N,lamb,t_eps=t_eps,p_T = p_T ,all_t=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e3bc9e4d",
   "metadata": {
    "id": "e3bc9e4d"
   },
   "source": [
    "### Markdown table"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "228e7b63",
   "metadata": {
    "id": "228e7b63"
   },
   "source": [
    "In the following, the table is displayed in the notebook via Markdown."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "adef2818",
   "metadata": {
    "id": "adef2818"
   },
   "outputs": [],
   "source": [
    "def formatting_number(x) :\n",
    "    if x == 0 :\n",
    "        str_x = '0'\n",
    "    elif x == np.inf :\n",
    "        str_x = '-'\n",
    "    elif np.log10(x).is_integer() :\n",
    "        str_x = '10^{'+str(int(np.log10(x)))+'}'\n",
    "    elif  x > 10**2 :\n",
    "        str_x = '{:1.1E}'.format(x)\n",
    "    elif x < 10**-2 :\n",
    "        str_x =  '{:1.1E}'.format(x)\n",
    "    else :\n",
    "        str_x =  '{:1.2f}'.format(x)\n",
    "    return str_x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "nZ_S9F5vJBbQ",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 644
    },
    "id": "nZ_S9F5vJBbQ",
    "outputId": "06f3bd0e-a1e7-4827-ab30-66975cd74616"
   },
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "||| Continuous||  N =  50||  N =  250||  N =  500||  N =  1000||\n",
       "|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|:---:|\n",
       "|||$p_T$|$\\mathcal{N}_0$|$p_T$|$\\mathcal{N}_0$|$p_T$|$\\mathcal{N}_0$|$p_T$|$\\mathcal{N}_0$|$p_T$|$\\mathcal{N}_0$|\n",
       "|EM|$\\varepsilon = 0$|0|6.7E-04|4.78|4.78|0.65|0.66|0.32|0.32|0.16|0.16|\n",
       "||$\\varepsilon = 10^{-5}$|4.1E-03|4.2E-03|4.77|4.77|0.66|0.66|0.32|0.32|0.16|0.16|\n",
       "||$\\varepsilon = 10^{-4}$|0.03|0.03|4.76|4.76|0.66|0.66|0.32|0.32|0.17|0.17|\n",
       "||$\\varepsilon = 10^{-3}$|0.18|0.18|4.68|4.68|0.70|0.70|0.40|0.40|0.27|0.27|\n",
       "|EI|$\\varepsilon = 0$|0|6.7E-04|2.81|2.81|0.57|0.57|0.30|0.30|0.16|0.16|\n",
       "||$\\varepsilon = 10^{-5}$|4.1E-03|4.2E-03|2.81|2.81|0.57|0.57|0.30|0.30|0.16|0.16|\n",
       "||$\\varepsilon = 10^{-4}$|0.03|0.03|2.82|2.82|0.58|0.58|0.31|0.31|0.17|0.17|\n",
       "||$\\varepsilon = 10^{-3}$|0.18|0.18|2.91|2.91|0.67|0.67|0.41|0.41|0.29|0.29|\n",
       "|Euler|$\\varepsilon = 0$|0|0.07|1.72|1.78|0.38|0.44|0.20|0.26|0.10|0.17|\n",
       "||$\\varepsilon = 10^{-5}$|4.1E-03|0.07|1.72|1.78|0.38|0.44|0.20|0.26|0.10|0.17|\n",
       "||$\\varepsilon = 10^{-4}$|0.03|0.08|1.72|1.78|0.38|0.44|0.20|0.26|0.11|0.17|\n",
       "||$\\varepsilon = 10^{-3}$|0.18|0.19|1.73|1.79|0.42|0.48|0.27|0.32|0.21|0.25|\n",
       "|Heun|$\\varepsilon = 0$|0|0.07|-|-|-|-|-|-|-|-|\n",
       "||$\\varepsilon = 10^{-5}$|4.1E-03|0.07|23.42|23.42|2.86|2.87|1.05|1.06|0.37|0.38|\n",
       "||$\\varepsilon = 10^{-4}$|0.03|0.08|4.68|4.68|0.43|0.44|0.12|0.14|0.03|0.08|\n",
       "||$\\varepsilon = 10^{-3}$|0.18|0.19|0.58|0.59|0.13|0.15|0.16|0.18|0.17|0.19|\n"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "table_Markdown = '|||'\n",
    "table_Markdown += ' Continuous||'\n",
    "\n",
    "for N in N_list :\n",
    "    table_Markdown += '  N =  ' +str(N)+'||'\n",
    "\n",
    "table_Markdown += '\\n'\n",
    "\n",
    "table_Markdown += '|:---:|:---:|:---:|:---:|'\n",
    "for N in N_list :\n",
    "    table_Markdown += ':---:|:---:|'\n",
    "\n",
    "table_Markdown += '\\n'\n",
    "\n",
    "table_Markdown += '|||$p_T$|$\\mathcal{N}_0$|'\n",
    "for N in N_list :\n",
    "    table_Markdown += '$p_T$|$\\mathcal{N}_0$|'\n",
    "\n",
    "table_Markdown += '\\n'\n",
    "\n",
    "\n",
    "for scheme in schemes_list :\n",
    "    table_Markdown += '|'+scheme+'|'\n",
    "    for t_eps in eps_list :\n",
    "        if t_eps != eps_list[0] :\n",
    "          table_Markdown += '||'\n",
    "        table_Markdown += r'$\\varepsilon = '+formatting_number(t_eps)+'$|'\n",
    "        if scheme in ['EM','EI'] :\n",
    "            table_Markdown += formatting_number(W2_dict['SDE']['True'][str(t_eps)])+'|'\n",
    "            table_Markdown += formatting_number(W2_dict['SDE']['False'][str(t_eps)])+'|'\n",
    "        if scheme in ['Euler','Heun'] :\n",
    "            table_Markdown += formatting_number(W2_dict['ODE']['True'][str(t_eps)])+'|'\n",
    "            table_Markdown += formatting_number(W2_dict['ODE']['False'][str(t_eps)])+'|'\n",
    "        for N in N_list :\n",
    "          table_Markdown += formatting_number(W2_dict[scheme]['True'][str(N)][str(t_eps)])+'|'\n",
    "          table_Markdown += formatting_number(W2_dict[scheme]['False'][str(N)][str(t_eps)])+'|'\n",
    "        table_Markdown += '\\n'\n",
    "\n",
    "\n",
    "\n",
    "Markdown(table_Markdown)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f55b5b2",
   "metadata": {
    "id": "1f55b5b2"
   },
   "source": [
    "### Tex table"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "248770da",
   "metadata": {
    "id": "248770da"
   },
   "source": [
    "In the following, a table.tex is created and compiled (if pdflatex is available) to obtain Table 2 of [ [ 1 ] ](#ref1)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "63484109",
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "63484109",
    "outputId": "c55eadbf-0bc0-4fa5-c294-3c3720b39c39",
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "output_tex = PATH_output + 'table.tex'\n",
    "\n",
    "#preamble\n",
    "table_tex  = r'\\documentclass{article}' + '\\n'\n",
    "table_tex  += '\\n'\n",
    "table_tex  += r'\\usepackage{booktabs}' + '\\n'\n",
    "table_tex  += r'\\usepackage{multirow}' + '\\n'\n",
    "table_tex  += r'\\usepackage{graphicx}' + '\\n'\n",
    "table_tex  +='\\n'\n",
    "table_tex  += r'\\begin{document}' + '\\n'\n",
    "table_tex  +='\\n'\n",
    "#Table\n",
    "table_tex  += r'\\begin{table}' + '\\n'\n",
    "table_tex += r'\\centering' + '\\n'\n",
    "table_tex += r'\\begin{tabular}{'\n",
    "table_tex += 'l'*(len(N_list)*len(P_T)+4) + '} \\n'\n",
    "table_tex += r'\\toprule' + '\\n'\n",
    "\n",
    "table_tex += r'&'\n",
    "table_tex += r' &\\multicolumn{2}{c}{Continuous}' + '\\n'\n",
    "\n",
    "for N in N_list :\n",
    "    table_tex += r'& \\multicolumn{2}{c}{$N = '+str(N)+ r'$}' + '\\n'\n",
    "\n",
    "table_tex += r'\\\\' +'\\n'\n",
    "\n",
    "for k in range(2,len(N_list)*len(P_T)+4,2) :\n",
    "    table_tex += r'\\cmidrule(lr){'+str(k+1) +'-'+str(k+2)+ r'}' + '\\n'\n",
    "\n",
    "table_tex += r'& &$p_T$ & $\\mathcal{N}_0$ & ' + '\\n'\n",
    "for N in N_list :\n",
    "    if N == N_list[-1] :\n",
    "        table_tex += r'$p_T$ & $\\mathcal{N}_0$ \\\\' + '\\n'\n",
    "    else :\n",
    "        table_tex += r'$p_T$ & $\\mathcal{N}_0$ &' + '\\n'\n",
    "\n",
    "table_tex += r'\\midrule' + '\\n'\n",
    "\n",
    "for scheme in schemes_list :\n",
    "    table_tex += r'\\parbox[t]{2mm}{\\multirow{4}{*}{\\rotatebox[origin=c]{90}{'+scheme+r'}}}' + '\\n'\n",
    "    #Continuous column\n",
    "    for t_eps in eps_list :\n",
    "        table_tex += r'& \\multicolumn{1}{|l}{$\\varepsilon = '+formatting_number(t_eps)+'$}\\n'\n",
    "\n",
    "        if scheme in ['EM','EI'] :\n",
    "            table_tex += ' & '+formatting_number(W2_dict['SDE']['True'][str(t_eps)])+'\\n'\n",
    "            table_tex += ' & '+formatting_number(W2_dict['SDE']['False'][str(t_eps)])+'\\n'\n",
    "        if scheme in ['Euler','Heun'] :\n",
    "            table_tex += ' & '+formatting_number(W2_dict['ODE']['True'][str(t_eps)])+'\\n'\n",
    "            table_tex += ' & '+formatting_number(W2_dict['ODE']['False'][str(t_eps)])+'\\n'\n",
    "        for N in N_list :\n",
    "            table_tex += ' & '+formatting_number(W2_dict[scheme]['True'][str(N)][str(t_eps)])+'\\n'\n",
    "            table_tex += ' & '+formatting_number(W2_dict[scheme]['False'][str(N)][str(t_eps)])+'\\n'\n",
    "        table_tex +=  r'\\\\' + '\\n'\n",
    "\n",
    "table_tex += r'\\bottomrule' + '\\n'\n",
    "table_tex += r'\\end{tabular}' + '\\n'\n",
    "table_tex += r'\\end{table}' + '\\n'\n",
    "\n",
    "table_tex += r'\\end{document}'\n",
    "\n",
    "if os.path.exists(output_tex) :\n",
    "    os.remove(output_tex)\n",
    "\n",
    "f = open(output_tex, \"a\")\n",
    "f.write(table_tex)\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "55ecb89d",
   "metadata": {},
   "source": [
    "The following cell compiles the file .tex if latex is available."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "edecf2b4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "from distutils.spawn import find_executable\n",
    "if find_executable('latex'):\n",
    "    os.system('pdflatex -v '+output_tex)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bd2c20ba",
   "metadata": {
    "id": "bd2c20ba"
   },
   "source": [
    "# Bibliography"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f0f8833d",
   "metadata": {
    "id": "f0f8833d"
   },
   "source": [
    "<a id=\"ref1\"/>\n",
    "\n",
    "[1] (2024). Diffusion models for Gaussian distributions: Exact solutions and Wasserstein errors. Preprint.\n",
    "\n",
    "<a id=\"ref2\"/>\n",
    "\n",
    "[2] [Yang Song, Jascha Sohl-Dickstein, Diederik P. Kingma, Abhishek Kumar, Stefano Ermon, Ben Poole (2021). Score-Based Generative Modeling through Stochastic Differential Equations. ICLR](https://iclr.cc/virtual/2021/oral/3402)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "38b9dedd",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
