{
 "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": 13,
   "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.00507739718142533 1.086705169143207\n",
      "tensor(0.8000, dtype=torch.float64) tensor(0.8000, dtype=torch.float64)\n",
      "0.811525042289861 0.8047815162405482\n",
      "tensor(1.6000, dtype=torch.float64) tensor(1., dtype=torch.float64)\n",
      "1.536937749667467 0.9819789647842669\n",
      "tensor(2.4000, dtype=torch.float64) tensor(1.6000, dtype=torch.float64)\n",
      "2.4357399847367014 1.6319004897045934\n",
      "tensor(3.2000, dtype=torch.float64) tensor(2.6000, dtype=torch.float64)\n",
      "3.2689100582174615 2.6161002356955194\n",
      "tensor(4., dtype=torch.float64) tensor(4., dtype=torch.float64)\n",
      "3.9685291695160614 4.041015860525717\n"
     ]
    },
    {
     "data": {
      "image/png": "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jTfeYM+ePXz++ecEBwfz1ltvNTpWo4ceeojly5fz6KOP0q1bNzIzM9myZQtHjx6lV69edcZ0+PBhhg4dio+PD08//TTOzs58+umnjBgxgk2bNtG/f38efPBBWrVqxeuvv87jjz9O3759CQkJMek1R0ZGcvfdd/PZZ5/x7LPP1jkLZUoc1dX2OTKaOHEiXbt25c033+T333/n1Vdfxd/fn08//ZQrr7ySt956i++++46ZM2fSt29fhg0b1qT3vi4HDx7kmmuuISgoiJdeeomKigpefPFFk9+7+j6nN998M8ePH+f777/nvffeIzAwEMCsr0cw7X0fO3YsXl5e/PDDDxf9crts2TK6d+9etYYiNTWVAQMGoNFoePTRRwkKCuKPP/5g2rRp5OXl8eSTT14UQ32fS6PGvt7Gfi005nUYGf8KX9//u4bY+nuWKa+3oc9B165dGT58eINruAoKCoiPj+fhhx++6LkDBw7U+CNYeXk5ubm5Jr1n/v7+VevNAPR6PY899hj33Xcf0dHRJl3DaO/evXTq1AkfH58aj/fr1w+Affv2ER4ebtY1Af71r3/x/vvvc8011zB16lTOnTvHe++9R3l5Oddffz29e/cG4MEHHyQ5OZnVq1fXqLIwai7vS69evfj777/NGkMIsylCiHotWrRIAZSdO3cqH374oeLt7a0UFRUpiqIoEyZMUEaOHKkoiqK0bdtWGTt2bNV5xmOqi42NVQDlm2++qXrsxRdfVADl9ttvv+j4cePGKR4eHkpiYmLVYydOnFCcnJyU6v99jTHGxcVddN177723xjVvuukmJSAgoMZjpsZ64Ti+vr7KI488ctG5DRk/frzi4uKinDp1quqxpKQkxdvbWxk2bFjVYxs2bFAA5ccffzTputU/V6dOnVKcnJyUxx9/vOr54cOHK927dzc7jvo+R8bnHnjggarHKioqlNatWysajUZ58803qx7Pzs5W3N3dlXvuuafqsca+93UZP3684ubmpiQkJFQ9duTIEUWn0ykXfsuv7ZoNfU7feecdk+JoKEZT3vfbb79dCQ4OVioqKqoeS05OVrRarTJnzpyqx6ZNm6aEhYUpGRkZNcaZNGmS4uvrW+M9ru9zWZu6Xm99/+ca+7Vgzuu40PPPP68ASn5+fr2v55FHHrno68DIlt+zFMX011vf1xygDB8+vM7Xe+HrWL16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1LoLo/peryU19XUMHDgQgF27djU6gbLl9yxzXm99n4N//vkHDw+Pi8omq0tLSyM9Pf2itZAffPABGRkZF3WFM671MYVxrU9UVBQ///zzRc8///zz5OfnM3/+fNq3bw/U/f/k1ltv5d1332XhwoVV+x2VlpayaNEi+vfvb/YfdIzvybp165gxY0bV4++//z579uzh22+/Net61n5foPb3xtz3Zc+ePdx5551mvTYhzCUJlBCNUFfJSXXXX389ixcvxtfXl27duhEbG8u6desICAgweZyXXnqJNWvWMHjwYB5++GH0ej0ffvghUVFR7Nu3rwmvoOmx5ufn07p1a2699VZiYmLw8vJi3bp17Ny5s9b9bap79dVXWbt2LUOGDGH69Ok4OTnx6aefUlpayttvv22x12X03HPPsXjxYo4dO1ZjTZOt46iNJb5Oqnv55ZdZtWoVQ4cOZfr06VRUVPCf//yH7t27c+DAgXrPNeVzamx5/NxzzzFp0iScnZ0ZN24cnp6e7Nixg5EjR/Liiy/y0ksv1TmOOe+7s7MzN998M0uXLqWwsJB33333ouu9+eabbNiwgf79+3P//ffTrVs3srKy2LNnD+vWrTO57Kg2db1ea2jK62jXrh1RUVGsW7eOe++9t1Hj2/p7lqmvt76vOVPamB88eBCANWvWMH36dLp06cK2bduq/qiwe/dutm/fXrVtQWPW+gQGBjJ+/PiLHjfOrFR/rq7/J/3792fChAnMmjWLtLQ0OnTowNdff018fDxffPFFjetqNJoGX3dAQADjx49nxYoV3HnnnQwePJgtW7bw/fffc99995mdZFj7fYHa3xtz3pfdu3eTlZXFjTfeaFacQphLEighrGT+/PnodDq+++47SkpKGDx4MOvWrTO5Gxqovzj88ccfzJw5kxdeeIHw8HDmzJnD0aNH+eeff+waq4eHB9OnT2fNmjX89NNPGAwGOnTowMcff1zrXivVde/enc2bNzNr1izeeOMNDAYD/fv359tvv71o7yVL6NChA5MnT+brr7+2axy1scTXSXU9evRg9erVzJgxg9mzZ9O6dWtefvllkpOTG0ygTPmc9u3bl1deeYUFCxawatUqDAYDcXFxFy1Sr4+57/vEiRP5/PPP0Wg03HbbbRc9HxISwo4dO5gzZw4//fQTH3/8MQEBAXTv3v2i0k1z1fV6raGp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CfX19QwfPpw333zziJ9//vnnee2113jnnXf4559/cHd3Z+rUqTQ1NTk40r7hWM93Q0MDKSkpzJ07l5SUFL7//nvS09M555xzujaILDiFX3/9VU5ISJB37dolA/LWrVvVDqnfeP755+WYmBi1w+gTxo0bJ996663tH1ssFjk0NFSeN2+eilH1D6WlpTIgr1mzRu1Q+rTa2lo5Pj5e/v333+XJkyfLd955p9oh9Un333+/fPzxx6sdRr9x5plnytdee+0ht51//vnyFVdcoVJEfRcg//DDD+0fW61WOTg4WH7hhRfab6uqqpKNRqP85ZdfqhBh3/Lv5/tINm7cKANybm5up88rZqCcQElJCddffz2ffvopbm5uaofT71RXV+Pn56d2GL1eS0sLW7Zs4dRTT22/TaPRcOqpp7J+/XoVI+sfqqurAcTPsp3deuutnHnmmYf8nAu299NPPzFmzBguuugigoKCGDlyJO+//77aYfVZkyZNYuXKlWRkZACwbds2/u///o/TTz9d5cj6vpycHIqLiw/5m+Lt7c348ePF/04Hqa6uRpIkfHx8Ov0Ynf3CETpDlmWuvvpqbrrpJsaMGcO+ffvUDqlfycrK4vXXX+fFF19UO5Rer6ysDIvFwoABAw65fcCAAezZs0elqPoHq9XK7NmzOe6440hKSlI7nD7rq6++IiUlhU2bNqkdSp+3d+9e3n77bebMmcNDDz3Epk2buOOOOzAYDMycOVPt8PqcBx54gJqaGhISEtBqtVgsFp555hmuuOIKtUPr84qLiwGO+L+z7XOC/TQ1NXH//fdz2WWX4eXl1enHiRkoO3nggQeQJOmYlz179vD6669TW1vLgw8+qHbIvVpnn++DFRQUMG3aNC666CKuv/56lSIXhJ679dZb2blzJ1999ZXaofRZeXl53HnnnXz++ee4uLioHU6fZ7VaGTVqFM8++ywjR47khhtu4Prrr+edd95RO7Q+6euvv+bzzz/niy++ICUlhY8//pgXX3yRjz/+WO3QBMFuTCYTF198MbIs8/bbb3fpsWIGyk7uvvturr766mPeJzY2lj///JP169djNBoP+dyYMWO44oorxB+vTurs892msLCQk046iUmTJvHee+/ZObr+ISAgAK1WS0lJySG3l5SUEBwcrFJUfd9tt93G0qVLWbt2LeHh4WqH02dt2bKF0tJS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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": [
       "Waiting for wandb.init()..."
      ],
      "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_105438-be2s0bhx</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/be2s0bhx' target=\"_blank\">fine-flower-13</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/be2s0bhx' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/be2s0bhx</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": [
      "t: 0.0\n",
      "tensor(4.) tensor(4.)\n",
      "t: 0.05\n",
      "tensor(4.0025) tensor(3.9999)\n",
      "t: 0.1\n",
      "tensor(4.0072) tensor(3.9981)\n",
      "t: 0.15000000000000002\n",
      "tensor(4.0142) tensor(3.9900)\n",
      "t: 0.2\n",
      "tensor(4.0232) tensor(3.9680)\n",
      "t: 0.25\n",
      "tensor(4.0335) tensor(3.9232)\n",
      "t: 0.30000000000000004\n",
      "tensor(4.0440) tensor(3.8478)\n",
      "t: 0.35000000000000003\n",
      "tensor(4.0540) tensor(3.7373)\n",
      "t: 0.4\n",
      "tensor(4.0627) tensor(3.5910)\n",
      "t: 0.45\n",
      "tensor(4.0698) tensor(3.4110)\n",
      "t: 0.5\n",
      "tensor(4.0754) tensor(3.2010)\n",
      "t: 0.55\n",
      "tensor(4.0796) tensor(2.9646)\n",
      "t: 0.6000000000000001\n",
      "tensor(4.0827) tensor(2.7052)\n",
      "t: 0.65\n",
      "tensor(4.0848) tensor(2.4254)\n",
      "t: 0.7000000000000001\n",
      "tensor(4.0862) tensor(2.1272)\n",
      "t: 0.75\n",
      "tensor(4.0870) tensor(1.8119)\n",
      "t: 0.8\n",
      "tensor(4.0875) tensor(1.4803)\n",
      "t: 0.8500000000000001\n",
      "tensor(4.0876) tensor(1.1331)\n",
      "t: 0.9\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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(4.0876) tensor(0.7705)\n",
      "t: 0.9500000000000001\n",
      "tensor(4.0874) tensor(0.3928)\n",
      "t: 1.0\n",
      "tensor(4.0870) tensor(9.0599e-06)\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>01. Mean xt</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr><tr><td>02. Variance xt</td><td>▁▁▁▁▁▁▁▁▁▂▂▂▃▃▄▄▅▆▆▇█</td></tr><tr><td>03. Mean x1|xt</td><td>▁▁▂▂▃▄▅▅▆▇▇▇█████████</td></tr><tr><td>04. Variance x1|xt</td><td>████████▇▇▇▆▆▅▅▄▄▃▂▂▁</td></tr><tr><td>05. Mean xt|x1</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr><tr><td>06. Variance xt|x1</td><td>█▇▇▆▅▅▄▄▄▃▃▂▂▂▂▁▁▁▁▁▁</td></tr><tr><td>07. log p_t(x|x1)</td><td>▁▁▁▁▁▁▁▂▂▂▂▂▂▂▂▃▃▃▄▅█</td></tr><tr><td>08. log p(x1)</td><td>▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁▁</td></tr><tr><td>09. log p_t(x1|x)</td><td>▁▁▁▁▁▁▁▁▁▁▂▂▂▂▂▂▂▂▂▃█</td></tr><tr><td>10. log p_t(x)</td><td>▇██████▇▇▇▆▅▅▄▄▃▃▂▂▁▁</td></tr><tr><td>11. Loss (KL Divergence)</td><td>▁▁▁▁▁▁▁▁▁▁▁▁▁▁▂▂▂▃▄█▁</td></tr><tr><td>12. Loss (log probability)</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>01. Mean xt</td><td>4</td></tr><tr><td>02. Variance xt</td><td>4.00001</td></tr><tr><td>03. Mean x1|xt</td><td>4.08705</td></tr><tr><td>04. Variance x1|xt</td><td>1e-05</td></tr><tr><td>05. Mean xt|x1</td><td>4.08703</td></tr><tr><td>06. Variance xt|x1</td><td>1e-05</td></tr><tr><td>07. log p_t(x|x1)</td><td>4.37107</td></tr><tr><td>08. log p(x1)</td><td>-2.14329</td></tr><tr><td>09. log p_t(x1|x)</td><td>4.37122</td></tr><tr><td>10. log p_t(x)</td><td>-2.14332</td></tr><tr><td>11. Loss (KL Divergence)</td><td>0.02033</td></tr><tr><td>12. Loss (log probability)</td><td>-0.00011</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\">fine-flower-13</strong> at: <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/be2s0bhx' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/be2s0bhx</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_105438-be2s0bhx\\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",
    "\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({\"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",
    "run.finish()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "dcdd14a5-dd88-4963-8628-5eddd546e7f9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "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|x1</td><td>▁▁▂▂▂▃▃▃▄▄▅▅▅▆▆▆▇▇▇██</td></tr><tr><td>Variance x1|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></table><br/></div><div class=\"wandb-col\"><h3>Run summary:</h3><br/><table class=\"wandb\"><tr><td>Loss (KL Divergence)</td><td>-0.04265</td></tr><tr><td>Loss (log probability)</td><td>0.00018</td></tr><tr><td>Mean x1|xt</td><td>3.98124</td></tr><tr><td>Mean xt|x1</td><td>3.98134</td></tr><tr><td>Variance x1|xt</td><td>1e-05</td></tr><tr><td>Variance xt|x1</td><td>1e-05</td></tr><tr><td>log p(x1)</td><td>-1.40678</td></tr><tr><td>log p_t(x)</td><td>-1.40671</td></tr><tr><td>log p_t(x1|x)</td><td>4.36396</td></tr><tr><td>log p_t(x|x1)</td><td>4.36422</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\">blooming-disco-7</strong> at: <a href='https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/gklad35t' target=\"_blank\">https://wandb.ai/neuvar-flow-matching/bahrulnst-project/runs/gklad35t</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-20250418_204001-gklad35t\\logs</code>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "8f5bfb7f-c9ab-4945-871c-0ec33254bd9b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([4.2927, 4.2910])"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x1_xt_joint"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "fe681d3d-35f0-41ab-ab65-3554fd7d1361",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 1])"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x1_xt_joint.size()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "532415e5-4699-4fbf-83da-7cb87bf25ca5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "n_points = 1000\n",
    "x0 = torch.randn(n_points, 1)\n",
    "\n",
    "mu_target = torch.tensor([4.])\n",
    "sigma2_target = torch.tensor([1.])\n",
    "\n",
    "px1 = Normal(mu_target, torch.sqrt(sigma2_target))\n",
    "x1 = px1.rsample((n_points,1))\n",
    "\n",
    "tt = 0.5\n",
    "t_net = Regular_t()\n",
    "gt = t_net(torch.ones((1,1))*tt)\n",
    "alpha = gt.clone()\n",
    "beta2 = (1-gt)**2\n",
    "xt_x1 = g_t*x1 + (1-g_t)*x0\n",
    "\n",
    "ptx = pxt(mu_target, sigma2_target, alpha, beta2)\n",
    "pxt_g_x1 = pxt_given_x1(x1, alpha, beta2)\n",
    "\n",
    "px1_g_xt = p_x1_given_xt(mu_target, sigma2_target, \n",
    "                         alpha, beta2, xt_x1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5778e28a-6775-42ae-8ca9-712bd75225c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "log_pxt_g_x1 = pxt_g_x1.log_prob(xt_x1)\n",
    "log_px1 = pxt_g_x1.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",
    "left_kl = log_pxt_g_x1 + log_px1\n",
    "right_kl = log_px1_g_xt + log_ptx\n",
    "p1 = torch.mean(torch.exp(left_kl)*(left_kl - right_kl))\n",
    "p1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61678f76-02e3-4d60-9564-d215e025a8f3",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "n_points = 1000\n",
    "x0 = torch.randn(n_points, 1)\n",
    "\n",
    "mu_target = torch.tensor([4.])\n",
    "sigma2_target = torch.tensor([1.])\n",
    "\n",
    "px1 = Normal(mu_target, torch.sqrt(sigma2_target))\n",
    "x1 = px1.rsample((n_points,1))\n",
    "\n",
    "kld_res = []\n",
    "direct_logprob = []\n",
    "for tt in np.linspace(0,1,20):\n",
    "    t_net = Regular_t()\n",
    "    gt = t_net(torch.ones((1,1))*tt)\n",
    "    alpha = gt.clone()\n",
    "    beta2 = (1-0.997*gt)**2\n",
    "    xt_x1 = g_t*x1 + (1-g_t)*x0\n",
    "    \n",
    "    ptx = pxt(mu_target, sigma2_target, alpha, beta2)\n",
    "    pxt_g_x1 = pxt_given_x1(x1, alpha, beta2)\n",
    "    px1_g_xt = p_x1_given_xt(mu_target, sigma2_target, \n",
    "                             alpha, beta2, xt_x1)\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(p1.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())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "653695cf-176d-4681-bef1-c3ea39194ccc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]],\n",
       "\n",
       "        [[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]],\n",
       "\n",
       "        [[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]],\n",
       "\n",
       "        ...,\n",
       "\n",
       "        [[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]],\n",
       "\n",
       "        [[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]],\n",
       "\n",
       "        [[4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         ...,\n",
       "         [4.8902],\n",
       "         [4.8902],\n",
       "         [4.8902]]])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "log_pxt_g_x1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "e7afd43d-cc8d-4ae9-b3f2-47e9220558cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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oT179mjYsGHH7R82bJj27NnT5qJ+asuWLXI6nfrHP/6hjRs36oknntDcuXP1P//zPy1ed/fdd+uDDz7QwoUL9dlnn6m4uFiXX3651+sDAKC9au9rjnn0aCwzM1NvvvnmcUHkjTfeUO/evb1S2LHGjh2rsWPHul6np6crPz9fzzzzjB5//PETXlNRUaHnn39er7/+un7+859LkubPn68zzjhDX3/9tX72s595vU4AANqbpiC040C1jtQ1KCoizOSKvMujIDRjxgxdffXV+vzzz119hL788kstW7ZMb775plcLPJljZ7c+kby8PNXV1WnUqFGufVlZWerRo4dWrlx50iDkcDjkcDhcrysrK71XNAAAQSYpNlKxUeE6dKRe2w9UKyslzuySvMqjR2O5ublatWqVEhIS9O677+rdd99VQkKCVq9ercsuu8zbNR6noKBAs2fP1i233HLSc0pKSmSz2RQfH99sf3JyskpKSk563cyZM2W3211bWlqat8oGACDoWCyWdj1yzOPh89nZ2Xr11VeVl5envLw8vfrqq+rWrZseeeSRVr/HlClTZLFYWty2bNnS7JqioiKNHTtWV155pSZOnOhp+Sc1depUVVRUuLZdu3Z5/TMAAAgm7XnNMa9OEblnzx5NmzbtlJ2Ym0yePFkTJkxo8Zz09HTXz8XFxRoxYoSGDRumefPmtXhdSkqKamtrVV5e3uyuUGlpqVJSUk56XWRkpCIjI1tVPwAAoaA9rzlm6lzZiYmJSkxMbNW5RUVFGjFihLKzszV//nzXsh4nk52drYiICC1btky5ubmSpPz8fO3cuVM5OTltrh0AgFDRNIS+oB3eEfL40Zg/FRUVafjw4erRo4cef/xx7du3TyUlJc36+hQVFSkrK0urV6+WJNntdt18882aNGmSli9frry8PN10003KyclhxBgAAG5ouiO0bX+16hucJlfjXUGxetqSJUtUUFCggoICde/evdkxwzAkSXV1dcrPz1dNTY3r2BNPPCGr1arc3Fw5HA6NGTNGTz/9tF9rBwAg2HWL76CoCKuO1Dm1s6xG6UcXY20PLEZTkmiFSZMmtXh83759ev3119XQ0NDmwgJFZWWl7Ha7KioqFBfXvoYMAgDQWuOe+kIbiys17/psjT7r5H1tA0Vrv7/duiO0bt26U55zwQUXuPOWAAAgCGQmddTG4koV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uhPUJCg6SwMAAPgCQQgAAIQsgpBJIiMjNX36dNfw/1ARiu2mzaGBNoeOUGx3e24znaUBAEDI4o4QAAAIWQQhAAAQsghCAAAgZBGEAABAyCII+dDf//539erVS1FRURo6dKhWr17d4vkLFy5UVlaWoqKi1K9fP/3rX//yU6Xe5U67N27cqNzcXPXq1UsWi0VPPvmk/wr1Infa/Oyzz+r8889Xp06d1KlTJ40aNeqU/20EInfa/Pbbb2vw4MGKj49XTEyMBg4cqFdeecWP1XqHu3+nmyxYsEAWi0WXXnqpbwv0AXfa/OKLL8pisTTboqKi/Fitd7j751xeXq7bb79dqampioyM1Omnnx6U//92p93Dhw8/7s/aYrFo3LhxfqzYSwz4xIIFCwybzWa88MILxsaNG42JEyca8fHxRmlp6QnP//LLL42wsDBj1qxZxqZNm4z777/fiIiIML777js/V9427rZ79erVxj333GP83//9n5GSkmI88cQT/i3YC9xt87XXXmv8/e9/N9atW2ds3rzZmDBhgmG3243du3f7uXLPudvm5cuXG2+//baxadMmo6CgwHjyySeNsLAwY/HixX6u3HPutrnJtm3bjG7duhnnn3++cckll/inWC9xt83z58834uLijD179ri2kpISP1fdNu622eFwGIMHDzYuuugiY8WKFca2bduMTz/91Fi/fr2fK28bd9t94MCBZn/OGzZsMMLCwoz58+f7t3AvIAj5yJAhQ4zbb7/d9bqhocHo2rWrMXPmzBOef9VVVxnjxo1rtm/o0KHGLbfc4tM6vc3ddh+rZ8+eQRmE2tJmwzCM+vp6IzY21njppZd8VaLXtbXNhmEYgwYNMu6//35flOcTnrS5vr7eGDZsmPHcc88ZN954Y9AFIXfbPH/+fMNut/upOt9wt83PPPOMkZ6ebtTW1vqrRJ9o69/pJ554woiNjTWqqqp8VaLP8GjMB2pra5WXl6dRo0a59lmtVo0aNUorV6484TUrV65sdr4kjRkz5qTnByJP2h3svNHmmpoa1dXVqXPnzr4q06va2mbDMLRs2TLl5+frggsu8GWpXuNpmx988EElJSXp5ptv9keZXuVpm6uqqtSzZ0+lpaXpkksu0caNG/1Rrld40ub3339fOTk5uv3225WcnKy+ffvqkUceUUNDg7/KbjNv/H/s+eef1zXX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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(np.linspace(0,1,20)[:-5], np.array(direct_logprob)[:-5])\n",
    "plt.xlabel(\"t\")\n",
    "plt.ylabel(\"True Loss (from KLD)\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a5237c13-08a6-4977-94c1-83eaaf7d8b32",
   "metadata": {},
   "source": [
    "$   \\mathcal{L}_\\mathrm{NVFM}(\\theta,\\phi) \\leq - \\mathop{\\mathbb{E}}_{p_t^\\phi (x | x_1) p(x_1)} \\left[ \\log \\left( q_t^\\theta (x_1 | x) \\right) \\right] $\n",
    "$ + \\mathop{\\mathbb{E}}_{p_t^\\phi (x | x_1) p(x_1)} \\left[ \\log \\left( p_t^\\phi (x | x_1) \\right) \\right] $\n",
    "$- \\mathop{\\mathbb{E}}_{p_t^\\phi (x | x_1) p(x_1)p(x_1')} \\left[\\log p_t^\\phi(x|x_1') \\right]$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "dd3ba1f7-03a5-450f-9282-1710ad8df3dd",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([4.0647, 1.9550])\n",
      "tensor([5.4088, 3.1803])\n"
     ]
    }
   ],
   "source": [
    "print(x1.mean(dim=0))\n",
    "print(mu_post.mean(dim=0))"
   ]
  }
 ],
 "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
}
