{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f5027b0c-a53f-41bb-b17b-8dd70a54e466",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from gm_utils import visualize_density, sample, geodesic, energy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e5f02627-a309-45b1-b6e9-2a8bff614c7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# If latex is installed - for nicer formulas rendering in plots\n",
    "plt.rcParams['text.usetex'] = True\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{amsfonts}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3b84a3dc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Energy of pf ode trajectory: 0.14768564701080322 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2000/2000 [00:06<00:00, 286.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Energy of a geodesic: 0.09895339608192444\n",
      "Energy of pf ode trajectory: 0.1404285430908203 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2000/2000 [00:07<00:00, 282.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Energy of a geodesic: 0.08639109879732132\n",
      "Energy of pf ode trajectory: 0.15019121766090393 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 2000/2000 [00:06<00:00, 289.17it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Energy of a geodesic: 0.10196735709905624\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x124b87430>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 4))\n",
    "t_min = 0.1\n",
    "visualize_density(ax)\n",
    "for i, x in enumerate(torch.tensor([[1.], [0.], [-1.]])):\n",
    "    pf_ode_sample = sample(x, 512, t_start=1., t_end=t_min)\n",
    "    pf_ode_theta = torch.from_numpy(np.concatenate(pf_ode_sample, axis=1))\n",
    "    print('Energy of pf ode trajectory:', energy(pf_ode_theta).item(), end=' ')\n",
    "    theta1 = pf_ode_theta[0]\n",
    "    theta2 = pf_ode_theta[-1]\n",
    "    shortest_path12 = geodesic(theta1, theta2, n_opt_steps=2000, num_intermediate_points=512, num_nodes=10)\n",
    "    print('Energy of a geodesic:', energy(torch.from_numpy(shortest_path12)).item())\n",
    "    if i == 0:\n",
    "        label_pf = 'PF-ODE trajectory'\n",
    "        label_g = 'Spacetime Geodesic'\n",
    "    else:\n",
    "        label_pf = None\n",
    "        label_g = None\n",
    "    ax.plot(pf_ode_theta[:, 0], pf_ode_theta[:, 1], color='C3', label=label_pf)\n",
    "    ax.plot(shortest_path12[:, 0], shortest_path12[:, 1], color='C3', linestyle='--', label=label_g)\n",
    "ax.set_xlim((t_min, 1))\n",
    "ax.set_xticks([t_min, 1], [r'$0$', r'$T$'], fontsize=13)\n",
    "ax.set_yticks([])\n",
    "ax.set_xlabel(r'$t$', fontsize=14, labelpad=-10)\n",
    "ax.set_ylabel(r'$\\mathbf{x}$', fontsize=14)\n",
    "ax.legend()\n",
    "# plt.savefig('gaussian_mixture_pf_ode_geodesic.png', bbox_inches='tight', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c65ea22e",
   "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
}
