{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b0ed6ea1",
   "metadata": {},
   "source": [
    "# Validation of Isotropic Gaussian on SO(3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1f0207c3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "%pylab is deprecated, use %matplotlib inline and import the required libraries.\n",
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    }
   ],
   "source": [
    "%pylab inline\n",
    "import jax.numpy as jnp\n",
    "import jax\n",
    "from jaxlie import SO3\n",
    "from so3dm.distributions.isotropic_gaussian import IsotropicGaussianSO3, _isotropic_gaussian_so3_small, _isotropic_gaussian_so3"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5e3bdcf6",
   "metadata": {},
   "source": [
    "## Verify function f\n",
    "\n",
    "Here we test that the approximation matches well with the series"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3bc358fc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.lines.Line2D at 0x7f5b7c29b880>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "theta = jnp.linspace(0, pi)\n",
    "scale = 0.1\n",
    "lmax = 100\n",
    "\n",
    "subplot(211)\n",
    "plot(theta, _isotropic_gaussian_so3(theta, scale, lmax), '.-', label='Series')\n",
    "plot(theta, _isotropic_gaussian_so3_small(theta, scale),  label='Approximation')\n",
    "legend()\n",
    "\n",
    "subplot(212)\n",
    "plot(theta, (_isotropic_gaussian_so3_small(theta, scale) - _isotropic_gaussian_so3(theta, scale, lmax)))\n",
    "axhline(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bc16c76f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.lines.Line2D at 0x7f5b58539450>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "theta = jnp.linspace(0, pi)\n",
    "scale = 0.9\n",
    "lmax = 3\n",
    "\n",
    "subplot(211)\n",
    "plot(theta, _isotropic_gaussian_so3(theta, scale, lmax), '.-', label='Series')\n",
    "plot(theta, _isotropic_gaussian_so3_small(theta, scale),  label='Approximation')\n",
    "legend()\n",
    "\n",
    "subplot(212)\n",
    "plot(theta, (_isotropic_gaussian_so3_small(theta, scale) - _isotropic_gaussian_so3(theta, scale, lmax)))\n",
    "axhline(0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "226afb7d",
   "metadata": {},
   "source": [
    "## Verify that we recover something similar to a Gaussian for very small dispersion\n",
    "\n",
    "According to https://arxiv.org/abs/2206.08321, we should see something similar to a gaussian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c2864a79",
   "metadata": {},
   "outputs": [],
   "source": [
    "import tensorflow_probability as tfp; tfp = tfp.substrates.jax\n",
    "tfd = tfp.distributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "725643ce",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/francois/.local/lib/python3.10/site-packages/jax/_src/numpy/lax_numpy.py:1806: UserWarning: Explicitly requested dtype <class 'numpy.float64'> requested in array is not available, and will be truncated to dtype float32. To enable more dtypes, set the jax_enable_x64 configuration option or the JAX_ENABLE_X64 shell environment variable. See https://github.com/google/jax#current-gotchas for more.\n",
      "  lax_internal._check_user_dtype_supported(dtype, \"array\")\n",
      "/home/francois/.local/lib/python3.10/site-packages/jax/_src/numpy/lax_numpy.py:4457: UserWarning: Explicitly requested dtype <class 'numpy.float64'> requested in astype is not available, and will be truncated to dtype float32. To enable more dtypes, set the jax_enable_x64 configuration option or the JAX_ENABLE_X64 shell environment variable. See https://github.com/google/jax#current-gotchas for more.\n",
      "  lax_internal._check_user_dtype_supported(dtype, \"astype\")\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5b58433cd0>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "scale = 0.7\n",
    "scale_gaussian = sqrt(2)*scale\n",
    "theta = jnp.linspace(0, pi)\n",
    "\n",
    "plot(theta, _isotropic_gaussian_so3_small(theta, scale)/_isotropic_gaussian_so3_small(theta, scale).max(),  label='Approximation')\n",
    "plot(theta, tfd.Normal(0, scale_gaussian).prob(theta)/tfd.Normal(0, scale_gaussian).prob(theta).max(), '--',  label='Gaussian')\n",
    "legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "274d6052",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f5b583511e0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAD4CAYAAAD8Zh1EAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAAAnAUlEQVR4nO3deXxU9d328c83e0IStoQtQQgSRExYQkBUZHGpFPet4lLFtbSK1VqV+li91S63t1qrj1vdivgotC5Qq1gXEClS2VEJmywBIsgWtgSy/54/EnNnAyZhkjMzud6vV15mzu/MzDVz8MqZM2cx5xwiIhL8wrwOICIi/qFCFxEJESp0EZEQoUIXEQkRKnQRkRAR4dUTJyUluZ49e3r19CIiQWnJkiW7nHPJDY15Vug9e/Zk8eLFXj29iEhQMrNNhxvTJhcRkRChQhcRCREqdBGREOHZNnQRaVmlpaXk5eVRVFTkdRTxQUxMDKmpqURGRvp8HxW6SCuRl5dHQkICPXv2xMy8jiNH4Jxj9+7d5OXlkZaW5vP9jrrJxcxeNbMdZrbiMONmZk+b2Toz+9rMshqRW0RaSFFRER07dlSZBwEzo2PHjo3+NOXLNvTJwJgjjP8YSK/6uQV4vlEJRKTFqMyDR1OW1VEL3Tk3F8g/wiwXAlNcpS+BdmbWtdFJfJRfWMJj787jYMG+5noKEZGg5I+9XFKALTVu51VNq8fMbjGzxWa2eOfOnU16snnf7mTk8rvY9uQotuauadJjiIh3pk+fjpmxevVqT55/69atXHbZZX55rBkzZrBy5crq2w888ACffvqpXx67KfxR6A19LmjwqhnOuRedc9nOuezk5AaPXD2qCwamED36LpLLvydm8pmsmPfPJj2OiHhj6tSpDB8+nGnTpvnl8crKyho1f7du3Xj77bf98tx1C/3hhx/mrLPO8stjN4U/Cj0P6F7jdiqw1Q+Pe1gDRv+E/Vd/xIGwdvT95Fr+8+bvcBUVzfmUIuIHBQUFfPHFF7zyyivVhT5nzhxGjBjBxRdfTL9+/ZgwYQIVVf8/x8fHc9ddd5GVlcWZZ57JD5/sR40axX333cfIkSN56qmnmDVrFoMGDSIzM5MbbriB4uJiFi1aRP/+/SkqKqKwsJCTTjqJFStWkJubS0ZGBgCTJ0/moosu4vzzzyctLY1nnnmGP/3pTwwaNIhhw4aRn1+5tfmll15iyJAhDBgwgEsvvZSDBw8yf/583nvvPe6++24GDhzI+vXrGT9+fPUfi4YyQeVpTx588EGysrLIzMz06ycVf+y2+B5wm5lNA04G9jnntvnhcY8oNb0/BXfMJeeFq+myegr3ThvNQ5cNIzYqvLmfWiToPfTPHFZu3e/Xx+zXLZEHzz/piPPMmDGDMWPG0KdPHzp06MDSpUsBWLhwIStXrqRHjx6MGTOGd999l8suu4zCwkKysrJ44oknePjhh3nooYd45plnANi7dy+ff/45RUVFpKenM2vWLPr06cO1117L888/zx133MEFF1zA/fffz6FDh7jmmmvIyMggNze3VqYVK1awbNkyioqK6N27N48++ijLli3jzjvvZMqUKdxxxx1ccskl3HzzzQDcf//9vPLKK0ycOJELLriA8847r94mnKKiIsaPH99gJoCkpCSWLl3Kc889x+OPP87LL7/shyXg226LU4H/ACeYWZ6Z3WhmE8xsQtUsM4ENwDrgJeAXfknmg/jEDmTe9T6fnfoab32zl3HPf86uHc3+t0REmmjq1KmMGzcOgHHjxjF16lQAhg4dSq9evQgPD+fKK69k3rx5AISFhXHFFVcAcM0111RPB6qnr1mzhrS0NPr06QPAddddx9y5c4HKbdqffPIJixcv5p577mkw0+jRo0lISCA5OZm2bdty/vnnA5CZmVld/itWrOD0008nMzOTN954g5ycnCO+ziNlArjkkksAGDx4cL0/MMfiqGvozrkrjzLugFv9lqiRwsLDuWHMKfTs8T35U29h7dtdSfrFX7yKIxIUjrYm3Rx2797N7NmzWbFiBWZGeXk5ZsbYsWPr7aJ3uF32ak5v06YNUHkQzuHk5+dTUFBAaWkpRUVF1fepKTo6uvr3sLCw6tthYWHV2+fHjx/PjBkzGDBgAJMnT2bOnDlHfK1HylTzOcPDwxv9HcCRhMy5XM44sQu92oWTsf099u870l6WIuKFt99+m2uvvZZNmzaRm5vLli1bSEtLY968eSxcuJCNGzdSUVHB3/72N4YPHw5ARUVF9TbpN998s3p6TX379iU3N5d169YB8PrrrzNy5EgAbrnlFh555BGuvvpq7r333iZnP3DgAF27dqW0tJQ33nijenpCQgIHDhxoVKbmFDKFDpA46nYS7SArPnjB6ygiUsfUqVO5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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "scale = 0.2\n",
    "scale_gaussian = sqrt(2)*scale\n",
    "theta = jnp.linspace(0, pi)\n",
    "\n",
    "plot(theta, _isotropic_gaussian_so3_small(theta, scale)/_isotropic_gaussian_so3_small(theta, scale).max(),  label='Approximation')\n",
    "plot(theta, tfd.Normal(0, scale_gaussian).prob(theta)/tfd.Normal(0, scale_gaussian).prob(theta).max(), '--',  label='Gaussian')\n",
    "legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c6418817",
   "metadata": {},
   "source": [
    "## Checking the sampling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "30f30c28",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:The use of `check_types` is deprecated and does not have any effect.\n"
     ]
    }
   ],
   "source": [
    "dist = IsotropicGaussianSO3(SO3.identity(), 0.1)\n",
    "samples = dist.sample(1024, seed=jax.random.PRNGKey(0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "fc0bef29",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray([[ 0.9957812 , -0.02018663,  0.01465022, -0.0883047 ],\n",
       "             [ 0.9995942 , -0.00199915, -0.01604257,  0.02345193],\n",
       "             [ 0.997948  ,  0.06102636, -0.01659244,  0.01001197],\n",
       "             ...,\n",
       "             [ 0.9978874 ,  0.0361054 ,  0.02030388,  0.05004982],\n",
       "             [ 0.99542946, -0.01916886, -0.03541163,  0.0865956 ],\n",
       "             [ 0.997483  , -0.057759  , -0.00442982, -0.04088908]],            dtype=float32)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6fda4c58",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Let's look at the distribution of axis angles\n",
    "angles = jnp.linalg.norm(jax.vmap(lambda x: SO3(x).log())(samples),axis=-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3fa1cf1b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f5b583b90c0>]"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWoAAAD4CAYAAADFAawfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAAAdK0lEQVR4nO3deZhddZ3n8ff31hKykq1CdioLCRAiAQoJS1AQkUXFfexWGdExo40I3c5Ienp6enykHWZcWlqbp5txR0edYbEjAYRW9jWVhYTsqVBJKltVdrJW1T3f+ePcCjFUpU6Se+65557P63nqqeVe7v0ckudTv/zO7/yOuTsiIlK+ckkHEBGR41NRi4iUORW1iEiZU1GLiJQ5FbWISJmrjuNFhw8f7vX19XG8tIhIRVqwYMF2d6/r7rFYirq+vp7GxsY4XlpEpCKZ2fqeHtPUh4hImVNRi4iUORW1iEiZU1GLiJQ5FbWISJlTUYuIlDkVtYhImVNRi4iUORW1iEiZi+XKxCyonzPvyNfNd9/Y7c+PfUxE5GRoRC0iUuZU1CIiZU5FLSJS5lTUIiJlTkUtIlLmVNQiImVORS0iUuZU1CIiZU5FLSJS5lTUIiJlTkUtIlLmVNQiImVORS0iUuYiFbWZDTazB8xspZmtMLNL4w4mIiKhqNuc3gM87u4fM7NaoF+MmRLX0xamIiJJ6LWozWwQcCXwWQB3bwfa440lIiJdokx9TATagJ+Y2SIz+6GZ9T/2SWY228wazayxra2t6EFFRLIqytRHNXAhcJu7v2Jm9wBzgL89+knufh9wH0BDQ4MXO2g5O/auLlGepykVEYkqyoi6BWhx91cK3z9AWNwiIlICvRa1u28FNprZ1MKP3gMsjzVVClyTW8B3a+7lNA4nHUVEKlzUVR+3Ab8srPhYB9wSX6Ty0u10RdNT3FvzPWotT4dXc2fn7ITSiUgWRCpqd18MNMQbJSU2LYTffJp1PpoX89P4XPXjvBKczUPBlUknE5EKFXVELQA7muCXH4e+Q7l5753sYBDn5tZzV81PWNI+kbU+NumEIlKBdAl5Qf2ceUc+ujOCXXD/hwCHzzxMK0PIU8VX2r/MAfpwb8099OVQSTOLSDaoqCMYxH5+Vns3HNgJn3oAhk8+8lgrQ7ij41Ym22a+Xv2zBFOKSKVSUfeiD+38sPbbTLLN8O9+AWPevjLx+WA6389/iE9UP8NHc88mkFJEKpmKuhd/U/1LGmw1f9lxK0y6qsfn3dP5UV7Kn8s3an7CZGspYUIRqXQ6mXgcRsD1Va/wu+BS5gUzmXecKxADcnyl41Ye7fPX3FtzDx9o/3sOU1vCtCJSqTSiPo5zbAN1tpdn8u+I9Pw2hnBnx2ym5Dbxvtz8mNOJSFaoqI/jytwSAJ4Lpkf+b54KZtDqg7m2akFcsUQkY1TUxzErt5QVwXjaGBL5v3FyPJm/iHfnFlNLR4zpRCQrVNQ96MshGnKrePYERtNdnggaGGCHuCy3LIZkIpI1KuoeXJJbSR/r5Lkg2vz00V4KzuVN78u1ucYYkolI1mjVRw9m5ZZyyGuYH0zt/cnHaKeGp4PzeW/VAibM+R2u34cicgrUID2YlVvCq8HZJ73E7sl8A3W2hwtsbZGTiUjWqKi7MZIdTMlt4pmTmPbo8lQwg3av0uoPETllKupuzKpaCnBS89Nd3qQfLwfncm1uPpCpO5OJSJGpqLtxZW4J23wwq09x29InggYm5rYy2TYVKZmIZJGK+hg5Aq7IvV4YTdspvdaT+YsAtPpDRE6JivoY06yZIbaPZ/Mnvn76WNsYyuJgEtdWqahF5OSpqI8xq3DZ+AvBeUV5vSfyDczIrWMkO4ryeiKSPSrqY1xZtZSlQT07OL0or/f7ILzV5DVVC4vyeiKSPSrqo/TnIBfa6lNa7XGsJh9NUzBK89QictJU1EeZmVtOreVPaLe83hlPBg1cmlvOIPYX8XVFJCsiFbWZNZvZUjNbbGYVOzSclVvKAe/DgmBKUV/3ifxF1Fied+cWF/V1RSQbTmREfZW7z3D3htjSJGxWbikvB+fQTk1RX3eRT6bNT9fqDxE5KZr6KBhrbUzKbSnytEforT2qX6MP7UV/fRGpbFGL2oEnzGyBmc2OM1BSrsiFl40/W8QTiUfTHtUicrKiFvXl7n4hcD1wq5ldeewTzGy2mTWaWWNbW1tRQ5bCrNwSNvkwmnx0LK//YjCNQ17D5bnXY3l9EalckYra3TcXPrcCDwPv7OY597l7g7s31NXVFTdl3NyZmVvBi/lpnOpl4z1pp4bXfBINuVWxvL6IVK5ei9rM+pvZwK6vgWuByhoW7tvGMHuT131CrG/TGExhmq2nL4difR8RqSxR7vByBvCwmXU9//+4++Oxpiq11uUArPJxsb7N/GAqt1bPZUauifo58478vPnuG2N9XxFJt16L2t3XAeeXIEtythWKOji1bU17szA4i8CNBlvFS0yL9b1EpHJoeR5A63JafTC7GBTr2+xlAKt9LA251bG+j4hUFhU1QOtyVgbxTnt0aQymcGFuDTmCkryfiKSfijrIQ+vKU76bS1Tzg6kMtINMtY0leT8RST8V9a5m6DwY+4nELgt8KoCW6YlIZJku6vo58/iP37kfgFUlmvpo8eFs8aFcrKIWkYgyXdQAU20jgVvJpj7AWBBM4SKdUBSRiDJf1FNyG1nvIzhEn5K95/xgKmNsB6PZXrL3FJH0ynxRn20bWV2i+ekujYHmqUUkukwXdR/aqbetrCxxUa/0cezz07SeWkQiyXRRT7LNVFvA6hKdSOySp4qFwVk6oSgikWS6qLvWMpd6RA3h9MdU28hADpT8vUUkXbJd1LkWDns1zT6y5O/d6FPImXNhbk3J31tE0iXbRW0baPIx5Kkq+XsvDibT6TmdUBSRXmW7qHMbE5n2ADjAaSz3M2kwnVAUkePLblEf3M1o28nqmLc2PZ7GYCozcmuhUze8FZGeZbeoW1cAyZxI7DI/mEpfa4etSxLLICLlL8NFHd4NfFUwPrEIjcGU8IsNLyeWQUTKX4aLegV7vR9bGJpYhDaGsD4YARteSiyDiJS/7Bb1tuWs8rHEddfxqBp9Cmx8BdwTzSEi5SubRe0OrctKtrXp8TQGU2F/G+xcl3QUESlT2SzqN7fAoT0lu1nA8cwvbNCk6Q8R6Uk2i/rIXceTL+omHw19h+iEooj0KJtF3Voo6jIYUTs5GHsxtDQmHUVEylTkojazKjNbZGaPxBmoJFqXw8BR7GFA0klCYxqgbSUc2pt0EhEpQycyor4dWBFXkJLatgxGnJt0ireMvQhw2Lww6SQiUoYiFbWZjQVuBH4Yb5wSCPLQtgpGnJN0kreMuSj83DI/2RwiUpaijqi/B3wNCHp6gpnNNrNGM2tsa2srRrZ47FwH+cNwxrSkk7yl7xAYdha0LEg6iYiUoV6L2szeD7S6+3FbxN3vc/cGd2+oq6srWsCi2xZeOl5WI2oITyhuatSFLyLyNlFG1JcDHzSzZuDXwNVm9otYU8WpdQVYDurOTjrJnxp7UXjhy+71SScRkTLTa1G7+1+7+1h3rwc+CfzR3T8de7K4tC6DoROhpm/SSY6onzOPGx86HH6jZXoicozsraNuXVF+0x6E260e9FoVtYi8zQkVtbs/7e7vjytM7DoOhicTR5TRicSCPFUs9QnhPLWIyFGyNaLesRY8gLqpSSfp1qJgMoc3LmLKnN9SP2de0nFEpExkr6gBhk1ONkcPFgeT6WOdnGM6oSgib8lYUTeFn4dOTDZHDxYF4S+QC3JrE04iIuWkOukAJbWjiS0+lEv/7pmkk3RrK8PY6kPCG97mk04jIuUiYyPqtTQHI5NOcVyLgsnMsKakY4hIGclWUe9s4g0v76JeHEymPreNoWgnPREJZaeoD+yEAztY56OSTnJcXfPU5+c0qhaRUHaKunBPwnIfUS/1CXR6jgtya5KOIiJlIjtFXVia11zmRX2Q01jt4zRPLSJHZKiom8BybPAzkk7Sq0XB5HDlR9DjrrIikiEZKuq1MPhMOlKwInGxT2KQHYQdmv4QkawVdZlekXishcFZ4Re644uIkJWidg9PJg6blHSSSNb5KPZ6P+2kJyJAVop63zZo35eaEbWTY3EwSTvpiQiQlaI+shlTOkbUEM5Ts20ZtO9POoqIJCxjRZ2OETXAouCscEvWzYuTjiIiCctIUTdBVR8YNDbpJJG9FhRG/zqhKJJ52SnqoRMhl57D3ckgGFKveWoRyUpRr03V/PQRYy+GjfPDVSsiklmVX9RBHna9kc6iHncJ7NsKu3XHF5Esq/yi3rMR8u2pOpF4xLhLws8bXkk2h4gkqvKLOoUrPo44YxrUDoSNLyedREQSlIGiLuxCl8aizlXBuIs1ohbJuF6L2sxOM7NXzew1M1tmZl8vRbCi2dEUjkr71yWd5OSMmwmty+Hg7qSTiEhCooyoDwNXu/v5wAzgOjObGWuqYupa8WGWdJKTM/4SwLXvh0iG9VrUHtpX+Lam8JGe9WIp2jWvW2MawKo0Ty2SYZHmqM2syswWA63Ak+7+tklTM5ttZo1m1tjW1lbkmCep83C46iPNRd1nAIw8DzaoqEWyKlJRu3ve3WcAY4F3mtl53TznPndvcPeGuroymQ/e1Rzul5HGNdRHGzcTNi2AfEfSSUQkASe06sPddwNPA9fFEaboUrhrXrfGXwIdB2Dr0qSTiEgCoqz6qDOzwYWv+wLXACtjzlUcXUU9NOVFPa5w7najlumJZFGUEfUo4CkzWwLMJ5yjfiTeWEWyown6DYe+g5NOcmpOHwOnj9M8tUhG9XqnV3dfAlxQgizFt6Mp1ScS6+fMO/J1c8MlsP6FcIOmtC41FJGTUtlXJqZ9ad7Rxs+EN7fA7g1JJxGREqvcoj68L9x5Lu0nErt0bdCkeWqRzKnYor7xv/8MgC8+tifhJEXStUGT5qlFMqdii3qCbQHgDR+ZcJIi6dqgSSNqkcyp+KJurpSihnCZ3rZl2qBJJGN6XfWRVvW5rbT4cA5T+yerJ1Lt6A2azrom6TQiUiIVO6KeaFtpDs5IOkZxaYMmkUyq2KKeYFt4w0clHaO4tEGTSCZVZlEf2Mlg2195RQ3aoEkkgyqzqAt7fKyrpBOJXbRBk0jmVGZRb18DVNiKjy7aoEkkcyq0qFdz2KvZ6COSTlJ82qBJJHMqtKjX0OwjyVOVdJJY/OvOcWxd9gz1c9KxiaGInJrKLOoda2jy0UmniM38YCojbRfjrTXpKCJSApVX1PkO2LmOdZW44qPghSC8E9qsnE4oimRB5RX1rmYIOmkKKndE/YaPpMWHq6hFMqLyinr7aoCKnvoA49n8dC7LvQ75zqTDiEjMKraoK3nqA+D5YDqD7CBsXph0FBGJWQUW9RoYOIp99Es6SaxeCM4jcIOmPyYdRURiVoFFvRqGn5V0itjtYQBLfAI0PZV0FBGJWWUVtXuhqKcknaQkngveAS3z4VCF3MVGRLpVWUW9vy0srYwU9fP56eB5aH4+6SgiEqNei9rMxpnZU2a2wsyWmdntpQh2UgonErMw9QGw0M+Cmv6apxapcFFG1J3AV939HGAmcKuZnRtvrJN0pKizMaLuoBrqr1BRi1S4Xova3be4+8LC128CK4AxcQc7KdvXhCPMgZW8hvoYk66GnevCC31EpCKd0By1mdUDFwBv22PTzGabWaOZNba1tRUp3gnavhqGT4ZcZU29H9ekq8PPWv0hUrEiN5qZDQAeBO5w973HPu7u97l7g7s31NXVFTNjdBla8XHE8LNg0BhYp6IWqVSRitrMaghL+pfu/lC8kU5S+wHYvTF7RW0Gk66CdU9DkE86jYjEIMqqDwN+BKxw9+/GH+kk7WwCPDMrPv7ExKvCZYmbFyWdRERiEGVEfTnwGeBqM1tc+Lgh5lwnrnD7LYZltKgxzVOLVKjq3p7g7s8DVoIsp2b7GsBg2KSkk5Re/2Ew6h3hMr13/eek04hIkVXO8ojtq2HweKjpm3SSZEy6GlpehcNvJp1ERIqssoo6aycSjzbxKgg6dTm5SAXqdeojFYIAdqyF+llJJym5+jnzAKilg9UD+obz1FOvTziViBRTZYyo926CjgPZXPFR0E6NLicXqVCVUdQZ2+OjR5Ough1rwvXkIlIxKqSoC0vzsl7Uk68JP696NNkcIlJUFVLUq+G0wdB/eNJJklU3FUZMg6UPJJ1ERIqocop6+JTwcuqsm/6xcJnervVJJxGRIqmMVR/b17z1z/4K1bW6o1fnfRT+8HV4/UGY9VfxhhKRkkj/iPrQHti3NdMrPv7EkDNh7Ds1/SFSQdJf1NvXhp+zfiLxaNM/Bq3LoHVF0klEpAhSP/XxV/f+X75bC1f9bDNveMTpgUo37cPkH72Te//xbr7T+Qma774x6UQicgpSP6KelNtMu1ex0RO6WUE5GjCCF4Lz+GDuRcCTTiMipyj1RT3RtrDBz6Az/f84KKrfBZdyZq6V860p6SgicopSX9STbDNNnqGb2Ub0+/zFHPZqbqp6MekoInKK0l3U+U7qbauKuht76c/TwQzeX/WybtElknLpLurd66m1PE2Biro7c/OXMcJ2a+tTkZRLd1EXNmPSiLp7fwguYJ+fBq9rTbVImqX7DFyhqNf5qISDlIdjr148RB+eCBr4yPK5cMO3obpPQslE5FSke0S95TU2+TD20j/pJGVrbv5SOLQb1v4h6SgicpLSXdQtjSwKJiedoqw9H0yHvkM1/SGSYukt6n2tsHu9iroXnVTDuTfBqsegfX/ScUTkJKS3qFsaAVgUaDOmXk3/eHirspW6oYBIGvVa1Gb2YzNrNbPXSxEospb5kKthmdcnnaT8jb8UhtTDy/eC65JykbSJMqL+KXBdzDlOXMt8GDmdw9QmnaT85XJw+R2weSGseyrpNCJygnotand/FthZgizRBXnYtBDGXpx0kvSY8ecwcDQ8+52kk4jICSraHLWZzTazRjNrbGtrK9bLdq91BXTsh7EN8b5PJanuA5fdBuufhw0vJ51GRE5A0Yra3e9z9wZ3b6iri3nL0Zb54WcV9Ym56N9Dv2HwnEbVImmSzlUfLY1h4QyZkHSSdKntDzO/BGuegC2vJZ1GRCJKaVHPD+enddfxE3fxF6DPII2qRVIkyvK8XwEvAVPNrMXMPh9/rOM4uBu2r+JbywZFvzO3vKXvYHjnF2D5XGhblXQaEYkgyqqPP3P3Ue5e4+5j3f1HpQjWo00LAFjkuiLxpM38C6jpC89/L+kkIhJB+qY+WhoJ3FgSTEw6SXr1Hw4XfRaW/AZ2rU86jYj0IoVFPZ/VPpZ99Es6SWrUz5l35OOIy26DXBW8cE9ywUQkknQVtTu0zNdGTMUwaHR4EcyiX8CbW5NOIyLHka6i3tEEh3ZrfrpYLr8dgg7NVYuUuXQVdeFCl8UaURfH0Ilw4c3w6r/A+peSTiMiPUhfUdcOZK2PSTpJ5bj2Lhg8Hh6eDYf2JJ1GRLqRvqIecyFBymKXtT4D4SP/G/Zsgke/lnQaEelGem5u234Ati2DK/4SViQdJr16ukjojuqbuGPJr/lyYx0/+OZdJU4lIseTnqHplsXgeW1tGpPvd36YhcFk/r7mR7CnJek4InKU9BS1dsyLVZ4q7ui4lSoCePiL4Z7fIlIW0lXUQyaEV9VJLDb4GXy982Zofg5e/H7ScUSkIB1F7Q4b52vaowT+X/5dcM4H4Y93webFSccREdJS1Hs3wb6tKuqSMPjAPeG/XB64BXZvTDqQSOalo6gL89Mf+O1hbW1aCv2Gwsd/Bvu3w4+uDW99JiKJSUlRN3LYa1jp45NOkh3jL4FbHgMP4Mfv030WRRJU/kXdcQhWPsJin0RHipZ9V4SR58Hnn4D+dfDzm2Dlo0knEsmk8i/qF78Pu5r5fueHk06STUPOhM/9Hs6YBr/5FCz8edKJRDKnvIeou5rhuW/DuR/i+YXTk06TXf2Hw81zeeau63nX3Nv4zoPP8E/5Dx25lL/57hsTDihS2cp7RP34X4NVwfu+mXQS6TOAz3f8Jx7MX8FXax7gkdq/YVZuSdKpRDKhfIt61eOw6lF419fgdO2WVw46qearHV/iK+1fZgAHuL/2bu6v+SZseS3paCIVrTynPjoOwmNfY20wmusfmUDHI1qSl5S3L4c05gaX8Xj7xXy66t+4rfph+JcreTh/Od/p/ATP/4/PFu39NKUiEirPEfUL98Du9fxt5y1a6VGm2qnhx/nredfhf+Dezg9yfe5V/lD7VfjVn8HC+8M12CJSFOXXgjvfgOe+C+d9lJcapyWdRnqxl/78r85P8vPO9/KF6kf5/Nal4ZSV5WDcTDj7Bph6AwyblHRUkdSKVNRmdh1wD1AF/NDd744r0L/9wy3MzBnvabwqrreQGGxlGN/o/Azf2OZMs/VcW9XI7YfXwBP/NfwYcAbUnQ0jzoG6s/nIg7tZ62PYS/8epzg0DSIS6rWozawK+CfgvUALMN/M5rr78qKnWfUY11Qt4q6OT7GNoUV/eSkFY5nXs6yzntu/dGO4xHLV4+EJx7YV4TrsjgM81Cd89k4fAD8YE15U0384X6/ezw4/nV0M4CB9OOB9OEAfaD4davqFH1U1kKsufK6Bqurwc64qHMn/yYcl+n9DpBiijKjfCax193UAZvZr4CaguEVdOIG4OhjDT/PvK+pLS4KG1MPML771fRDAng187lv3M8VaGG07uHlEv3BOu3U5N1VtYrDtf/vr/PRbJxnACmV91Gc45mdHPffIlz0VfA8/1y8EgfCag9uLvwrK3P34TzD7GHCdu/+HwvefAS5x9y8f87zZwOzCt1OBVSeZaTiQtTNROubKl7XjBR3ziTrT3eu6eyDKiLq7ocLb2t3d7wPuO8Fgb38zs0Z3z9RtXHTMlS9rxws65mKKsjyvBRh31Pdjgc3FDiIiIt2LUtTzgbPMbIKZ1QKfBObGG0tERLr0OvXh7p1m9mXg94TL837s7stizHTK0ycppGOufFk7XtAxF02vJxNFRCRZ5XkJuYiIHKGiFhEpc4kUtZldZ2arzGytmc3p5nEzs38sPL7EzC5MImcxRTjmTxWOdYmZvWhm5yeRs5h6O+ajnnexmeULa/ZTLcoxm9m7zWyxmS0zs2dKnbHYIvzdPt3MfmdmrxWO+ZYkchaLmf3YzFrN7PUeHi9+f7l7ST8IT0g2AROBWuA14NxjnnMD8BjhGu6ZwCulzpnAMV8GDCl8fX0Wjvmo5/0ReBT4WNK5S/DnPJjwqt7xhe9HJJ27BMf8X4D/Wfi6DtgJ1Cad/RSO+UrgQuD1Hh4ven8lMaI+ckm6u7cDXZekH+0m4OceehkYbGajSh20iHo9Znd/0d13Fb59mXC9eppF+XMGuA14EGgtZbiYRDnmPwcecvcNAO6e9uOOcswODDQzAwYQFnVnaWMWj7s/S3gMPSl6fyVR1GOAjUd931L42Yk+J01O9Hg+T/gbOc16PWYzGwN8GPjnEuaKU5Q/5ynAEDN72swWmNnNJUsXjyjH/APgHMIL5ZYCt7t7UJp4iSh6fyWxH3WUS9IjXbaeIpGPx8yuIizqK2JNFL8ox/w94E53z1tlbGoU5ZirgYuA9wB9gZfM7GV3Xx13uJhEOeb3AYuBq4FJwJNm9py77405W1KK3l9JFHWUS9Ir7bL1SMdjZu8Afghc7+47SpQtLlGOuQH4daGkhwM3mFmnu/+2JAmLL+rf7e3uvh/Yb2bPAucDaS3qKMd8C3C3hxO4a83sDeBs4NXSRCy5ovdXElMfUS5JnwvcXDh7OhPY4+5bSh20iHo9ZjMbDzwEfCbFo6uj9XrM7j7B3evdvR54APiLFJc0RPu7/a/ALDOrNrN+wCXAihLnLKYox7yB8F8QmNkZhLtrritpytIqen+VfETtPVySbmZfLDz+z4QrAG4A1gIHCH8jp1bEY/5vwDDg3sIIs9NTvPNYxGOuKFGO2d1XmNnjwBIgILxjUrfLvNIg4p/zN4CfmtlSwmmBO909tdufmtmvgHcDw82sBfg7oAbi6y9dQi4iUuZ0ZaKISJlTUYuIlDkVtYhImVNRi4iUORW1iEiZU1GLiJQ5FbWISJn7/9mU9s8IlSjsAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "theta = jnp.linspace(0, 1)\n",
    "hist(angles,100, density=True, range=[0,1]);\n",
    "plot(theta, (1 - cos(theta))/pi*_isotropic_gaussian_so3_small(theta, 0.1/sqrt(2)))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dbcb8dfd",
   "metadata": {},
   "source": [
    "## Visualisation of the sampled distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "cb5f15ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "from so3dm.plotting import visualize_so3_probabilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d9096df5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:The use of `check_types` is deprecated and does not have any effect.\n",
      "/home/francois/repo/SO3DiffusionModels/so3dm/plotting.py:98: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([r'90$\\degree$', None,\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "center = SO3.from_x_radians(pi)\n",
    "dist = IsotropicGaussianSO3(center, 0.1)\n",
    "\n",
    "samples = dist.sample(1000, seed=jax.random.PRNGKey(0))\n",
    "prob = jnp.exp(dist.log_prob(samples));\n",
    "\n",
    "visualize_so3_probabilities(\n",
    "    jax.vmap(lambda x: SO3(x).as_matrix())(samples),\n",
    "    0.001*prob/prob.max(),\n",
    "    rotations_gt=center.as_matrix());"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "26d67293",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:The use of `check_types` is deprecated and does not have any effect.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "center = SO3.from_x_radians(0)\n",
    "dist = IsotropicGaussianSO3(center, 0.1)\n",
    "\n",
    "samples = dist.sample(1000, seed=jax.random.PRNGKey(0))\n",
    "prob = jnp.exp(dist.log_prob(samples));\n",
    "\n",
    "visualize_so3_probabilities(\n",
    "    jax.vmap(lambda x: SO3(x).as_matrix())(samples),\n",
    "    0.001*prob/prob.max(),\n",
    "    rotations_gt=center.as_matrix());"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7e468dad",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:The use of `check_types` is deprecated and does not have any effect.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "center = SO3.from_z_radians(pi)\n",
    "dist = IsotropicGaussianSO3(center, 0.1)\n",
    "\n",
    "samples = dist.sample(1000, seed=jax.random.PRNGKey(0))\n",
    "prob = jnp.exp(dist.log_prob(samples));\n",
    "\n",
    "visualize_so3_probabilities(\n",
    "    jax.vmap(lambda x: SO3(x).as_matrix())(samples),\n",
    "    0.001*prob/prob.max(),\n",
    "    rotations_gt=center.as_matrix());"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "f31156b3",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:The use of `check_types` is deprecated and does not have any effect.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "center = SO3.from_y_radians(3*pi/4)\n",
    "dist = IsotropicGaussianSO3(center, 0.1)\n",
    "\n",
    "samples = dist.sample(1000, seed=jax.random.PRNGKey(0))\n",
    "prob = jnp.exp(dist.log_prob(samples));\n",
    "\n",
    "visualize_so3_probabilities(\n",
    "    jax.vmap(lambda x: SO3(x).as_matrix())(samples),\n",
    "    0.001*prob/prob.max(),\n",
    "    rotations_gt=center.as_matrix());"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6674127d",
   "metadata": {},
   "source": [
    "## Checking the normalization of the distribution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "aafb70e8",
   "metadata": {},
   "outputs": [],
   "source": [
    "dist = IsotropicGaussianSO3(center, 0.2)\n",
    "\n",
    "value = 0\n",
    "nsamples = 10000000\n",
    "x = jax.vmap(lambda x: dist.log_prob(SO3.sample_uniform(x).wxyz))(jax.random.split(jax.random.PRNGKey(0),nsamples))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "1c55b8fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "x2 = jnp.exp(x - x.max())*jnp.exp(x.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1a7ee945",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray(0.991857, dtype=float32)"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x2.sum()/nsamples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "15814d55",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
