{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3a4e6cab-9f41-4855-9232-972e7470bb4e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch import Tensor\n",
    "from torch.distributions import Normal, MultivariateNormal\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import wandb"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "57510872-a225-4a82-887c-3907896020ff",
   "metadata": {},
   "source": [
    "\\begin{equation*}\n",
    "    p(x_1|x) = \\frac{p_t(x,x_1)}{p_t(x)} = \\frac{p_t(x|x_1)p(x_1)}{\\int p_t(x|x_1)p(x_1) dx_1}\n",
    "\\end{equation*}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "52a1ab46-deb0-4614-83c6-715758c4dcd2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ut_x_x1(x: torch.Tensor, x_1: torch.Tensor, gt: torch.Tensor, gt_prime: torch.Tensor):\n",
    "    ### source: https://diffusion.csail.mit.edu/docs/lecture-notes.pdf example 11, equation 21\n",
    "    p2 = -gt_prime/(1 - gt + 1e-3)\n",
    "    return (gt_prime - p2*gt)*x_1 + p2*x\n",
    "\n",
    "class Regular_t(nn.Module):\n",
    "    '''\n",
    "    just regular t to ensure it works in gaussian setting\n",
    "    '''\n",
    "    def __init__(\n",
    "        self \n",
    "    ) -> None:\n",
    "        super().__init__()\n",
    "\n",
    "    def forward(self, t : Tensor) -> Tensor:\n",
    "        return t\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "147f40b2-5a0b-4b2e-a45a-31c4cb27b04f",
   "metadata": {},
   "source": [
    "Case 1: $\\theta$ is fixed, $\\phi$ needs to learn\n",
    "\n",
    "$q_t^\\theta (x_1|x) = p(x_1|x)$\n",
    "\n",
    "Target\n",
    "\n",
    "$x_1 \\sim \\mathcal{N}(\\tilde{\\mu}, \\tilde{\\sigma}^2 I)$\n",
    "\n",
    "Interpolant \n",
    "\n",
    "$x_t|x_1 \\sim \\mathcal{N}(\\alpha_t x_1, \\beta_t^2 I)$\n",
    "\n",
    "Joint\n",
    "\n",
    "$x_1, x_t \\sim \\mathcal{N}\\left[\\begin{pmatrix}\n",
    "\\tilde{\\mu} \\\\\n",
    "\\alpha_t\\tilde{\\mu} \n",
    "\\end{pmatrix}, \\begin{pmatrix}\n",
    "\\tilde{\\sigma}^2 & \\alpha_t\\tilde{\\sigma}^2 \\\\\n",
    "\\alpha_t\\tilde{\\sigma}^2 & \\alpha_t^2\\tilde{\\sigma}^2 + \\beta_t^2\n",
    "\\end{pmatrix} \\right]$\n",
    "\n",
    "Marginal\n",
    "\n",
    "$x_t \\sim \\mathcal{N}(\\alpha_t\\tilde{\\mu},\\alpha_t^2\\tilde{\\sigma}^2 + \\beta_t^2)$\n",
    "\n",
    "Posterior\n",
    "\n",
    "$x_1|x_t \\sim \\mathcal{N}\\left(\\tilde{\\mu} + \\frac{\\alpha_t\\tilde{\\sigma}^2}{\\alpha_t^2\\tilde{\\sigma}^2 + \\beta_t^2} (x_t - \\alpha_t\\tilde{\\mu}), \\;\\;\\;\n",
    "\\tilde{\\sigma}^2 - \\frac{(\\alpha_t\\tilde{\\sigma}^2)^2}{\\alpha_t^2\\tilde{\\sigma}^2 + \\beta_t^2}  \n",
    "\\right)\n",
    "$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3986a571-2497-4f29-a0ef-c29c3ee09149",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "## define distributions\n",
    "\n",
    "## conditional distribution x_t\n",
    "def pxt_given_x1(x1, alpha, beta2): return Normal(alpha*x1, torch.sqrt(beta2))\n",
    "\n",
    "## marginal x_t\n",
    "def pxt(mu, sigma2, alpha, beta2): return Normal(torch.tensor(alpha*mu), torch.sqrt(((alpha**2) * sigma2) + beta2))\n",
    "\n",
    "## joint x1, xt\n",
    "def px1_xt(mu, sigma2, alpha, beta2):\n",
    "    mean_vector = torch.tensor([mu, alpha*mu])\n",
    "    covariance = torch.tensor([[sigma2, alpha * sigma2], \n",
    "                               [alpha * sigma2, (alpha**2) * sigma2 + beta2]])\n",
    "    return MultivariateNormal(mean_vector, covariance)\n",
    "\n",
    "## posterior distribution\n",
    "def p_x1_given_xt(mu, sigma2, alpha, beta2, xt):\n",
    "    p1 = alpha * sigma2 / ((alpha**2) * sigma2 + beta2)\n",
    "    p2 = xt - alpha*mu\n",
    "    p3 = (alpha**2) * sigma2\n",
    "    p4 = (alpha**2) * sigma2 + beta2\n",
    "    return Normal(mu + p1 * p2, torch.sqrt(sigma2 - ((p3**2) / p4)))\n",
    "    \n",
    "# plt.hist(x1[:,0].detach().numpy())\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8bf32a70-a59b-4683-af5b-eb9c94d039fd",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0., dtype=torch.float64) tensor(1., dtype=torch.float64)\n",
      "-0.010686480804642368 1.0211187644098978\n",
      "tensor(0.8000, dtype=torch.float64) tensor(0.8000, dtype=torch.float64)\n",
      "0.7827506335167422 0.7554038222486651\n",
      "tensor(1.6000, dtype=torch.float64) tensor(1., dtype=torch.float64)\n",
      "1.5947211296656296 1.1029687810199011\n",
      "tensor(2.4000, dtype=torch.float64) tensor(1.6000, dtype=torch.float64)\n",
      "2.453765496699219 1.7481499847402957\n",
      "tensor(3.2000, dtype=torch.float64) tensor(2.6000, dtype=torch.float64)\n",
      "3.1100744643817095 2.649466167905183\n",
      "tensor(4., dtype=torch.float64) tensor(4., dtype=torch.float64)\n",
      "4.080612708712431 4.19651502345683\n"
     ]
    },
    {
     "data": {
      "image/png": "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zWeffUZISAivvfaaxbEa3X///SxevJiHHnqIrl27kpOTw8aNGzl8+DB9+vRpMKaDBw8ydOhQ/P39eeKJJ3B3d+eTTz5hxIgRrFu3joEDB3LffffRunVrXn75ZR555BH69+9PaGioSa85KiqKO+64g08//ZSnnnqqwVEnU+Korb7vkdGkSZPo0qULr776Kn/++Sf//e9/CQoK4pNPPuHKK6/ktdde47vvvmPWrFn079+fYcOGWfXeN2T//v1cddVVBAcH89xzz1FVVcWzzz5r8nvX2Pf0pptu4tixY3z//fe8/fbbtGzZEsCsn0cw7X0fN24cvr6+/PTTTxf8Uvvjjz/SrVu3mjUSmZmZDBo0CI1Gw0MPPURwcDDLli1jxowZFBQU8Nhjj10QQ2PfSyNLX6+lPwuWvA4j41/dG/t31xRHf2aZ8nqb+h506dKF4cOHN7lGq6ioiMTERB544IELntu3b1+dP35VVlaSn59v0nsWFBRUs54MQK/X8/DDD3P33XfTvXt3k9ow2rNnDx07dsTf37/O8QEDBgAQHx9PmzZtzGoT4F//+hfvvPMOV111FXfddRenT5/m7bffprKykuuuu46+ffsCcN9995Gens6KFSvqzKowuljelz59+rBp0yaz+hDCZIoQolELFixQAGXHjh3K+++/r/j5+SklJSWKoijKLbfcoowcOVJRFEVp166dMm7cuJrrjOfUtmXLFgVQvv7665pjzz77rAIot9566wXnjx8/XvHx8VFSU1Nrjh0/flxxc3NTav/zNcaYkJBwQbvTp0+v0+aNN96otGjRos4xU2M9v5+AgADln//85wXXNmXChAmKh4eHcvLkyZpjaWlpip+fnzJs2LCaY3///bcCKIsWLTKp3drfq5MnTypubm7KI488UvP88OHDlW7dupkdR2PfI+Nz9957b82xqqoqJSIiQtFoNMqrr75ac/zs2bOKt7e3cuedd9Ycs/S9b8iECRMULy8vJSkpqebYoUOHFJ1Op5z/kV9fm019T19//XWT4mgqRlPe91tvvVUJCQlRqqqqao6lp6crWq1WeeGFF2qOzZgxQwkPD1eys7Pr9DN58mQlICCgznvc2PeyPg293sb+zVn6s2DO6zjf008/rQBKYWFho6/nn//85wU/B0aO/MxSFNNfb2M/c4AyfPjwBl/v+a9jxYoVdY6npKQo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xQGwc+dOixMnR35mmfN6G/seHDlyBB8fnwumR9Z25swZsrKyLljr+O6775KdnX1BlTfjWh5TGNfyxMbG8uuvv17w/NNPP01hYSHz5s2jffv2QMP/Tm6++WbeeOMN5s+fX7NfUXl5OQsWLGDgwIFm/yHH+J6sXr2amTNn1hx/55132L17N99++61Z7dn7fYH63xtz35fdu3dz2223mfXahDCVJE5CWKChqSW1XXfddXzzzTcEBATQtWtXtmzZwurVq2nRooXJ/Tz33HOsXLmSK664ggceeAC9Xs/7779PbGws8fHxVrwC62MtLCwkIiKCm2++mZ49e+Lr68vq1avZsWNHvfvT1Pbf//6XVatWMWTIEB588EHc3Nz45JNPKC8vZ+7cuTZ7XUb/+c9/+Oabbzh69GidNUuOjqM+tvg5qe35559n+fLlDB06lAcffJCqqiree+89unXrxr59+xq91pTvqbF08X/+8x8mT56Mu7s748ePp1mzZmzfvp2RI0fy7LPP8txzzzXYjznvu7u7OzfddBM//PADxcXFvPHGGxe09+qrr/L3338zcOBA7rnnHrp27Upubi67d+9m9erVJk8vqk9Dr9cerHkd0dHRxMbGsnr1aqZPn25R/47+zDL19Tb2M2dKOfL9+/cDsHLlSh588EE6d+7M1q1ba/6YsGvXLrZt21az/YAla3latmzJhAkTLjhuHEmp/VxD/04GDhzILbfcwuzZszlz5gwxMTF89dVXJCYm8vnnn9dpV6PRNPm6W7RowYQJE1iyZAm33XYbV1xxBRs3buT777/n7rvvNju5sPf7AvW/N+a8L7t27SI3N5cbbrjBrDiFMJUkTkLYybx589DpdHz33XeUlZVxxRVXsHr1apOrm4H6C8OyZcuYNWsWzzzzDG3atOGFF17g8OHDHDlyxKmx+vj48OCDD7Jy5Up++eUXDAYDMTExfPjhh/XulVJbt27d2LBhA7Nnz+aVV17BYDAwcOBAvv322wv2TrKFmJgYpk6dyldffeXUOOpji5+T2nr06MGKFSuYOXMmc+bMISIigueff5709PQmEydTvqf9+/fnxRdf5OOPP2b58uUYDAYSEhIuWHzeGHPf90mTJvHZZ5+h0WiYOHHiBc+Hhoayfft2XnjhBX755Rc+/PBDWrRoQbdu3S6Yommuhl6vPVj7OqZPn86cOXMo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",
      "text/plain": [
       "<Figure size 1000x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns \n",
    "\n",
    "mu_target = 4.\n",
    "sigma2_target = 4.\n",
    "\n",
    "# Initialize the figure\n",
    "plt.figure(figsize=(10, 5))\n",
    "\n",
    "# Define the range for mu\n",
    "t_s = np.linspace(0, 1, 6)  # mu will go from 1 to 5\n",
    "\n",
    "# Set different colors for each histogram\n",
    "colors = ['r', 'g', 'b', 'c', 'm', \n",
    "          'y', 'k', 'w', 'orange', 'purple']\n",
    "\n",
    "# Loop over each mu value, generate samples, and update the histogram\n",
    "for t, color in zip(t_s, colors):\n",
    "    alpha = t\n",
    "    alpha2 = t**2\n",
    "    \n",
    "    beta = 1 - t\n",
    "    beta2 = torch.tensor(beta**2)\n",
    "    # Generate mu random samples (randn generates samples from N(0,1))\n",
    "    p_xt = pxt(mu_target, sigma2_target, alpha, beta2)\n",
    "    x = p_xt.rsample((1000,1)).numpy().reshape(-1)\n",
    "    print(p_xt.mean, p_xt.variance)\n",
    "    print(x.mean(), x.var())\n",
    "    # x = alpha * mu_target + np.sqrt((alpha2 * sigma2_target + beta)) * np.random.randn(1000)  # Scale by mu\n",
    "    # Plot the density (normalized histogram) in the same figure\n",
    "    # plt.hist(x, bins=30, density=True, alpha=0.5, color=color, \n",
    "    #          label=f't={np.round(t, 1)}')\n",
    "    sns.kdeplot(x, color=color, label=f't={np.round(t, 1)}', \n",
    "                shade=False)\n",
    "\n",
    "# Add titles and labels\n",
    "plt.title(f'Marginals of Normal dist. over time (Target: $\\mu$={mu_target}, $\\sigma^2$={sigma2_target})')\n",
    "plt.xlabel('Value')\n",
    "plt.ylabel('Density')\n",
    "\n",
    "# Add a legend to identify different mu values\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c8c4137c-43ec-46fd-925e-8e2fd3998ff0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: \u001b[32m\u001b[41mERROR\u001b[0m Failed to detect the name of this notebook. You can set it manually with the WANDB_NOTEBOOK_NAME environment variable to enable code saving.\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: Using wandb-core as the SDK backend.  Please refer to https://wandb.me/wandb-core for more information.\n",
      "\u001b[34m\u001b[1mwandb\u001b[0m: Currently logged in as: \u001b[33mbahrulnst\u001b[0m (\u001b[33mneuvar-flow-matching\u001b[0m) to \u001b[32mhttps://api.wandb.ai\u001b[0m. Use \u001b[1m`wandb login --relogin`\u001b[0m to force relogin\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "creating run (0.0s)"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Tracking run with wandb version 0.19.9"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Run data is saved locally in <code>C:\\Users\\dokug\\OneDrive - The University of Manchester\\PhD\\coding\\project\\benchmarks\\tabsyn\\baselines\\tabnvfm\\wandb\\run-20250421_112831-999st72t</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Syncing run <strong><a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/999st72t' target=\"_blank\">serene-plant-14</a></strong> to <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project' target=\"_blank\">Weights & Biases</a> (<a href='https://wandb.me/developer-guide' target=\"_blank\">docs</a>)<br>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View project at <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run at <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/999st72t' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/999st72t</a>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Start a new wandb run to track this script.\n",
    "run = wandb.init(\n",
    "    # Set the wandb entity where your project will be logged (generally your team name).\n",
    "    entity=\"neuvar-flow-matching\",\n",
    "    # Set the wandb project where this run will be logged.\n",
    "    project=\"bahrulnst-project\",\n",
    "    # Track hyperparameters and run metadata.\n",
    "    config={\n",
    "        # \"learning_rate\": 0.02,\n",
    "        # \"architecture\": \"CNN\",\n",
    "        # \"dataset\": \"CIFAR-100\",\n",
    "        # \"epochs\": 10,\n",
    "    },\n",
    ")\n",
    "\n",
    "# wandb.define_metric(\"t\")\n",
    "# # set all other train/ metrics to use this step\n",
    "# wandb.define_metric(\"*\", step_metric=\"t\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3ba38082-fa94-44e6-8f52-89c65073eef1",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(4.0920) tensor(3.7494)\n",
      "t: 0.0\n",
      "tensor(4.) tensor(4.)\n",
      "t: 0.05\n",
      "tensor(4.0108) tensor(3.9999)\n",
      "t: 0.1\n",
      "tensor(4.0242) tensor(3.9981)\n",
      "t: 0.15000000000000002\n",
      "tensor(4.0397) tensor(3.9900)\n",
      "t: 0.2\n",
      "tensor(4.0560) tensor(3.9680)\n",
      "t: 0.25\n",
      "tensor(4.0717) tensor(3.9232)\n",
      "t: 0.30000000000000004\n",
      "tensor(4.0854) tensor(3.8478)\n",
      "t: 0.35000000000000003\n",
      "tensor(4.0963) tensor(3.7373)\n",
      "t: 0.4\n",
      "tensor(4.1040) tensor(3.5910)\n",
      "t: 0.45\n",
      "tensor(4.1088) tensor(3.4110)\n",
      "t: 0.5\n",
      "tensor(4.1112) tensor(3.2010)\n",
      "t: 0.55\n",
      "tensor(4.1118) tensor(2.9646)\n",
      "t: 0.6000000000000001\n",
      "tensor(4.1111) tensor(2.7052)\n",
      "t: 0.65\n",
      "tensor(4.1095) tensor(2.4254)\n",
      "t: 0.7000000000000001\n",
      "tensor(4.1073) tensor(2.1272)\n",
      "t: 0.75\n",
      "tensor(4.1049) tensor(1.8119)\n",
      "t: 0.8\n",
      "tensor(4.1023) tensor(1.4803)\n",
      "t: 0.8500000000000001\n",
      "tensor(4.0997) tensor(1.1331)\n",
      "t: 0.9\n",
      "tensor(4.0971) tensor(0.7705)\n",
      "t: 0.9500000000000001\n",
      "tensor(4.0946) tensor(0.3928)\n",
      "t: 1.0\n",
      "tensor(4.0922) tensor(9.0599e-06)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: \u001b[32m\u001b[41mERROR\u001b[0m The nbformat package was not found. It is required to save notebook history.\n"
     ]
    },
    {
     "data": {
      "text/html": [],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<br>    <style><br>        .wandb-row {<br>            display: flex;<br>            flex-direction: row;<br>            flex-wrap: wrap;<br>            justify-content: flex-start;<br>            width: 100%;<br>        }<br>        .wandb-col {<br>            display: flex;<br>            flex-direction: column;<br>            flex-basis: 100%;<br>            flex: 1;<br>            padding: 10px;<br>        }<br>    </style><br><div class=\"wandb-row\"><div class=\"wandb-col\"><h3>Run history:</h3><br/><table class=\"wandb\"><tr><td>Loss (KL Divergence)</td><td>▁▁▁▁▁▁▁▁▁▁▁▁▁▁▂▂▂▃▄█▁</td></tr><tr><td>Loss (log probability)</td><td>▁▁▁▁▁▁▁▁▂▂▂▃▃▃▄▄▅▆▇█▁</td></tr><tr><td>Mean x1|xt</td><td>▁▂▃▃▅▅▆▇████████▇▇▇▇▇</td></tr><tr><td>Mean xt</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr><tr><td>Mean xt|x1</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr><tr><td>Variance x1|xt</td><td>████████▇▇▇▆▆▅▅▄▄▃▂▂▁</td></tr><tr><td>Variance xt</td><td>▁▁▁▁▁▁▁▁▁▂▂▂▃▃▄▄▅▆▆▇█</td></tr><tr><td>Variance xt|x1</td><td>█▇▇▆▅▅▄▄▄▃▃▂▂▂▂▁▁▁▁▁▁</td></tr><tr><td>log p(x1)</td><td>▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁</td></tr><tr><td>log p_t(x)</td><td>▇▇█████▇▇▇▆▆▅▅▄▃▃▂▂▁▁</td></tr><tr><td>log p_t(x1|x)</td><td>▁▁▁▁▁▁▁▁▁▁▁▂▂▂▂▂▂▂▂▃█</td></tr><tr><td>log p_t(x|x1)</td><td>▁▁▁▁▁▁▁▂▂▂▂▂▂▂▂▃▃▃▄▅█</td></tr><tr><td>t</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr></table><br/></div><div class=\"wandb-col\"><h3>Run summary:</h3><br/><table class=\"wandb\"><tr><td>Loss (KL Divergence)</td><td>0.02211</td></tr><tr><td>Loss (log probability)</td><td>-9e-05</td></tr><tr><td>Mean x1|xt</td><td>4.09216</td></tr><tr><td>Mean xt</td><td>4</td></tr><tr><td>Mean xt|x1</td><td>4.09202</td></tr><tr><td>Variance x1|xt</td><td>1e-05</td></tr><tr><td>Variance xt</td><td>4.00001</td></tr><tr><td>Variance xt|x1</td><td>1e-05</td></tr><tr><td>log p(x1)</td><td>-2.08136</td></tr><tr><td>log p_t(x)</td><td>-2.08145</td></tr><tr><td>log p_t(x1|x)</td><td>4.37584</td></tr><tr><td>log p_t(x|x1)</td><td>4.37566</td></tr><tr><td>t</td><td>1</td></tr></table><br/></div></div>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       " View run <strong style=\"color:#cdcd00\">serene-plant-14</strong> at: <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/999st72t' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/999st72t</a><br> View project at: <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project</a><br>Synced 5 W&B file(s), 0 media file(s), 0 artifact file(s) and 0 other file(s)"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "Find logs at: <code>.\\wandb\\run-20250421_112831-999st72t\\logs</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_points = 1000\n",
    "x0 = torch.randn(n_points, 1)\n",
    "\n",
    "mu_target = torch.tensor(4.)\n",
    "sigma2_target = torch.tensor(4.)\n",
    "\n",
    "px1 = Normal(mu_target, torch.sqrt(sigma2_target))\n",
    "x1 = px1.rsample((n_points,1))\n",
    "print(x1.mean(), x1.var())\n",
    "kld_res = []\n",
    "direct_logprob = []\n",
    "for tt in np.linspace(0,1,21):\n",
    "\n",
    "    ## this part is just to adapt the t network of neural vfm\n",
    "    t_net = Regular_t()\n",
    "    gt = t_net(torch.ones(1)*tt) \n",
    "    alpha = gt.clone()\n",
    "    beta2 = (1-0.997*gt)**2\n",
    "    xt_x1 = alpha*x1 + torch.sqrt(beta2)*x0\n",
    "    print(f't: {tt}')\n",
    "    \n",
    "    '''obtain the joint probability distribution\n",
    "    (optional)\n",
    "    '''\n",
    "    \n",
    "    # px1_xt_ = px1_xt(mu_target, sigma2_target, alpha, beta2)\n",
    "    # print(px1_xt_.mean) \n",
    "    # print(px1_xt_.covariance_matrix)\n",
    "    # x1_xt_joint = px1_xt_.rsample((n_points, 1))\n",
    "    # print(x1_xt_joint.mean(dim=0), x1_xt_joint.var(dim=0))\n",
    "\n",
    "    ## obtain the conditional distribution (just for debug)\n",
    "    pxt_g_x1 = pxt_given_x1(x1, alpha, beta2)\n",
    "    # xt_x1 = pxt_g_x1.sample()\n",
    "    # print(pxt_g_x1.mean.mean(), pxt_g_x1.variance.mean())\n",
    "    \n",
    "    ## obtain the posterior distribution (just for debug)\n",
    "    px1_g_xt = p_x1_given_xt(mu_target, sigma2_target, \n",
    "                             alpha, beta2, xt_x1)\n",
    "    ptx = pxt(mu_target, sigma2_target, alpha, beta2)\n",
    "    print(px1_g_xt.mean.mean(), px1_g_xt.variance.mean())\n",
    "    \n",
    "    log_pxt_g_x1 = pxt_g_x1.log_prob(xt_x1)\n",
    "    log_px1 = px1.log_prob(x1)\n",
    "    \n",
    "    log_px1_g_xt = px1_g_xt.log_prob(x1)\n",
    "    log_ptx = ptx.log_prob(xt_x1)\n",
    "\n",
    "    ## using KL divergence\n",
    "    left_kl = log_pxt_g_x1 + log_px1\n",
    "    right_kl = log_px1_g_xt + log_ptx\n",
    "    kl_value = torch.mean(torch.exp(left_kl)*(left_kl - right_kl))\n",
    "    kld_res.append(kl_value.numpy())\n",
    "    \n",
    "    ## using direct log probability\n",
    "    lp1 = torch.mean(- log_px1_g_xt + log_pxt_g_x1 - log_ptx + log_px1)\n",
    "    direct_logprob.append(lp1.numpy())\n",
    "\n",
    "    run.log({\"Mean xt\": ptx.mean.mean(),\n",
    "             \"Variance xt\": ptx.variance.mean(),\n",
    "             \"Mean x1|xt\": px1_g_xt.mean.mean(),\n",
    "             \"Variance x1|xt\": px1_g_xt.variance.mean(),\n",
    "             \"Mean xt|x1\": pxt_g_x1.mean.mean(),\n",
    "             \"Variance xt|x1\": pxt_g_x1.variance.mean(),\n",
    "             \"log p_t(x|x1)\": torch.mean(log_pxt_g_x1), \n",
    "             \"log p(x1)\": torch.mean(log_px1),\n",
    "             \"log p_t(x1|x)\": torch.mean(log_px1_g_xt),\n",
    "             \"log p_t(x)\": torch.mean(log_ptx),\n",
    "             'Loss (KL Divergence)': kl_value,\n",
    "             'Loss (log probability)': lp1,\n",
    "             't': tt \n",
    "            })\n",
    "run.finish()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "108cd275-ef21-445a-a002-0420df998e4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "    # run.log({\"01. Mean xt\": ptx.mean.mean(),\n",
    "    #          \"02. Variance xt\": ptx.variance.mean(),\n",
    "    #          \"03. Mean x1|xt\": px1_g_xt.mean.mean(),\n",
    "    #          \"04. Variance x1|xt\": px1_g_xt.variance.mean(),\n",
    "    #          \"05. Mean xt|x1\": pxt_g_x1.mean.mean(),\n",
    "    #          \"06. Variance xt|x1\": pxt_g_x1.variance.mean(),\n",
    "    #          \"07. log p_t(x|x1)\": torch.mean(log_pxt_g_x1), \n",
    "    #          \"08. log p(x1)\": torch.mean(log_px1),\n",
    "    #          \"09. log p_t(x1|x)\": torch.mean(log_px1_g_xt),\n",
    "    #          \"10. log p_t(x)\": torch.mean(log_ptx),\n",
    "    #          '11. Loss (KL Divergence)': kl_value,\n",
    "    #          '12. Loss (log probability)': lp1,\n",
    "    #          't': tt \n",
    "    #         })\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (flowm)",
   "language": "python",
   "name": "flowm"
  },
  "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
