{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "254ebdff",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "469a71ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "# If you have latex installed (For nice latex rendering)\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{amsfonts}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5e13253f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:02<00:00, 350.13it/s]\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "from gm_utils import geodesic\n",
    "\n",
    "theta1 = torch.tensor([0.35, -2.3]) #(theta=(t, x))\n",
    "theta2 = torch.tensor([0.4, 2])\n",
    "\n",
    "num_discretization_points = 128\n",
    "num_optimization_steps = 1000\n",
    "\n",
    "shortest_path12 = geodesic(theta1, theta2, num_optimization_steps, num_discretization_points)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aef7aaa0",
   "metadata": {},
   "source": [
    "If the data distribution $p_0$ is a Gaussian Mixture, then the denoising distribution $p(x_0\\mid x_t)$ is also a Gaussian mixture.\n",
    "\n",
    "Specifically, if $p_0 = \\sum_i \\pi_i \\mathcal{N}(\\mu_i, \\sigma^2I)$, and $p_{t|0}(x_t\\mid x_0) = \\mathcal{N}(x_t\\mid \\alpha_tx_0, \\sigma_t^2I)$, then\n",
    "\n",
    "$$p_{0|t}(x_0\\mid x_t) = \\frac{p_0(x_0)p_{t|0}(x_t\\mid x_0)}{p_t(x_t)} = \\sum_i \\pi_i \\mathcal{N}(x_0\\mid\\tilde{\\mu}_i, \\tilde{\\sigma}_t^2I),$$\n",
    "where\n",
    "\\begin{align}\n",
    "\\tilde{\\sigma}_t^2 &= \\left( \\frac{1}{\\sigma^2} + \\frac{\\alpha_t^2}{\\sigma_t^2} \\right)^{-1} \\\\\n",
    "\\tilde{\\mu}_i & = \\tilde{\\sigma}_t^2 \\left( \\frac{\\mu_i}{\\sigma^2} + \\frac{\\alpha_t^2}{\\sigma_t^2}x_t  \\right)\n",
    "\\end{align}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4bbd7143-e528-40ef-87ce-4c7c7be8fbf9",
   "metadata": {},
   "outputs": [],
   "source": [
    "from gm_utils import get_means_and_variances # Implementation of the above means and variance for the denoising Gaussian mixture"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "19b2197a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from gm_utils import visualize_density\n",
    "\n",
    "\n",
    "def visualize_density_w_geodesic(ax):\n",
    "    visualize_density(ax)\n",
    "    ax.set_xlabel(r\"$t$\", labelpad=-12, fontsize=14)\n",
    "    ax.set_yticks([])\n",
    "    ax.set_xticks([0, 1], [r'$0$', r'$T$'], fontsize=14)\n",
    "    ax.scatter(*theta1.numpy(), color='blue', s=5)\n",
    "    ax.scatter(*theta2.numpy(), color='red', s=5)\n",
    "\n",
    "    points = shortest_path12\n",
    "\n",
    "    segments = np.concatenate([points[:-1, None], points[1:, None]], axis=1)\n",
    "    norm = plt.Normalize(0, len(points) - 1)\n",
    "    cmap = LinearSegmentedColormap.from_list('blue_red_gradient', ['blue', 'red'], N=len(points))\n",
    "\n",
    "    lc = LineCollection(segments, cmap=cmap, norm=norm)\n",
    "    lc.set_array(np.arange(len(points)))\n",
    "    lc.set_linewidth(2)\n",
    "\n",
    "    ax.add_collection(lc)\n",
    "    ax.yaxis.set_label_position(\"right\")\n",
    "    ax.yaxis.tick_right()\n",
    "    ax.set_ylabel(r\"$\\mathbf{x}$\", fontsize=14)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d9c9de45",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.collections import LineCollection\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "from scipy.stats import norm\n",
    "\n",
    "from gm_utils import weights\n",
    "\n",
    "fig, (ax2, ax1) = plt.subplots(ncols=2, figsize=(5, 3), width_ratios=[1, 3])\n",
    "\n",
    "visualize_density_w_geodesic(ax1)\n",
    "\n",
    "num_plots = num_discretization_points\n",
    "\n",
    "cmap = LinearSegmentedColormap.from_list('blue_red_gradient', ['blue', 'red'], N=num_plots)\n",
    "colors = [cmap(i / (num_plots - 1)) for i in range(num_plots)]\n",
    "\n",
    "indices = np.round(np.linspace(0, num_plots - 1, num_plots)).astype(np.int32)\n",
    "x = np.linspace(-6, 8, 1000)\n",
    "max_pdf = 0\n",
    "\n",
    "for idx in range(num_plots):\n",
    "    theta = torch.from_numpy(shortest_path12[idx])\n",
    "    mean, var = get_means_and_variances(theta[0], theta[1])\n",
    "    pdf = np.zeros_like(x)\n",
    "    for mean_i, weight_i in zip(mean, weights):\n",
    "        pdf += weight_i.item() * norm.pdf(x, loc=mean_i, scale=var ** 0.5)\n",
    "    pdf = pdf\n",
    "    max_pdf = max(max_pdf, np.max(pdf))\n",
    "    if idx == 0 or idx == num_plots - 1:\n",
    "        alpha = 1\n",
    "    else:\n",
    "        alpha = 0.3\n",
    "    ax2.plot(-pdf, x, color=colors[idx], alpha=alpha)\n",
    "    ax2.set_ylim((-4, 4))\n",
    "    ax2.set_xlim((-1.1 * max_pdf, 0))\n",
    "\n",
    "ax2.set_xlabel(r'$\\mathbf{x}_0 \\mid \\mathbf{x}_t$', fontsize=14)\n",
    "ax2.set_xticks([])\n",
    "ax2.set_yticks([])\n",
    "plt.subplots_adjust(wspace=0.02)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e02645f4-8a56-4d88-908f-60918d525480",
   "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.10.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
