{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ab12f31b-b486-4d80-a6ea-7ef47ac614a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b11186f2-ec68-4943-b13a-c4321b74857d",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-01-31 04:44:07.072549: E external/local_xla/xla/stream_executor/cuda/cuda_fft.cc:477] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "WARNING: All log messages before absl::InitializeLog() is called are written to STDERR\n",
      "E0000 00:00:1738298647.091267   20623 cuda_dnn.cc:8310] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "E0000 00:00:1738298647.096802   20623 cuda_blas.cc:1418] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "/root/workspace/GitHub/pmlr-v202-finzi23a/.venv/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import functools\n",
    "import itertools\n",
    "import pprint\n",
    "\n",
    "import orbax.checkpoint\n",
    "import numpy as np\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import torch.utils.data.dataloader\n",
    "import tensorflow as tf\n",
    "import sqlalchemy as sa\n",
    "import seaborn as sns\n",
    "sns.set_theme(style='whitegrid', font_scale=1.3, palette=sns.color_palette('husl'),)\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from userdiffusion import samplers, unet\n",
    "from userfm import cs, datasets, event_constraints, diffusion, sde_diffusion, flow_matching, utils, main as main_module, plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f864ed5e-0ae5-49d2-b609-c893a21abf7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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/46Nhw8f1oIFCzRo0CB16dKl6JhUeHyz2+2aPXu2+vbtqy5dumjQoEFavXq1pIIzz4VDcW699Vb1799fK1asKPVY2dnZeu+99zRmzBjddddd6ty5s+6880795je/UWpqaqn1q3pcS09P129+85uiY++oUaP01VdfVeJZvrqAgAANGzZMkrRjxw5JUlJSksLDwxUbG6sdO3Zo3LhxioyMLMoeUtljdotnkDVr1mjEiBHq2rWrIiMjNXnyZB07dqzMGs6cOaO//e1veuihh9S1a1dFRERo8ODBeuutt2SzlRzmevr0af3lL38pyhM9e/bUuHHjtH379mp9XiTCbrUzm8169tlnJRWMt73SxQFRUVGaMGGCAgMDFRgYqAkTJmjChAkaO3asIiMjNWHCBLVs2VKSitoq+k2tLC+88IKmT58up9OpIUOG6IknnlBERIRSU1P1zTffXHX7c+fOadSoUYqPj1eDBg305JNPKioqSikpKYqJidHChQvL3O6rr77SU089JX9/f40aNUo9evRQYmKinnjiCZ06darK+wP3M5vNGj58uLZt21biQ97pdGrJkiXq1q2b2rZt68YKUVvuuOMORURE6MKFC/riiy/KXKfwi8/lX44WLVrEFyMPd6Vj344dO/Twww/rs88+U9euXRUTE6OuXbvqs88+08MPP6wffvihzD7feOMNzZ49W7fccovGjh2r7t27l2ifPHmyli9frrvuuktDhw7VkSNHNHnyZG3cuFGTJk3Sp59+qjvuuEPDhg1TVlaWpk6dquTk5BJ97N+/X7Nnz5bFYlHfvn315JNPKiIiQuvXr9ejjz6qnTt3lllbZY5rBw8e1MiRI7V27Vp169ZNY8eOVdOmTTV+/HitW7eu0s/1lRQ+715eJePd9u3b9dhjj+nixYt6+OGHNWzYsAp9sfzoo480depUtWzZUo899pjatWunzz//XNHR0bLb7SXWPXz4sIYPH665c+eqXr16Gj16tB5++GE1bdpU8+bNK/G8FK77r3/9S02bNtXjjz+uqKgobd++XU888YTWr19fDc/G/2EYQw2IiIiQt7e3Tp48qYyMDIWEhJS5XlRUlKKioooGml/+85DVatXmzZuVmZlZqZ8ay5Kdna3Vq1erU6dOWrRoUYmLCFwul86cOXPVPt566y399NNPGj16tF599dWi5c8884xGjBih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vzwu7Pbt21cmk6lC6zIbAwAAwPXN48JueWdqXS6XsrKylJeXd8X1AAAAcP3wuLB7pdkYnE6nNm3apNdff12dOnXSW2+9VYuVAQAAoK4x1AVqZrNZd955p+bOnauEhATNmzfP3SUBAADAjQwVdgu1atVKXbp00SeffOLuUgAAAOBGhgy7khQYGKiMjAx3lwEAAAA3MmTYPXXqlFJSUtSgQQN3lwIAAAA38rgL1LZs2VJum81mU1pamj766COdOXNGw4cPr8XKAAAAUNd4XNgdM2bMVefZdblcateunaZMmVJLVQEAAKAu8riw27Nnz3LbfHx81KRJE1mtVg0YMEA+Pj61WBkAAADqGo8LuwsWLHB3CQAAAPAQhrxADQAAAJA88Mzu5Y4fP65jx45Jkpo2baomTZq4uSIAAADUFR4bdhcuXKj3339fhw4dKrH85ptv1i9+8Qs9+uijbqoMAAAAdYVHht2pU6dq5cqVcrlc8vb2VosWLSRJR44cUXp6ul599VVt3bpVM2fOdHOlAAAAcCePC7vLli3TihUr1KRJE02ePFmDBw+W2WyWJDmdTn322Wf629/+ppUrV6p3794aMmSImysGAACAu3jcBWqLFy9WvXr1NH/+fA0bNqwo6EqS2WzWsGHDNH/+fFksFi1evNiNlQIAAMDdPC7s7tmzR1arVa1bty53ndatW6tXr17avXt37RUGAACAOsfjwu7FixcVEBBw1fUCAgJkt9troSIAAADUVR4Xdps3b65t27YpLy+v3HXy8vK0bds2NW/evBYrAwAAQF3jcWH33nvv1c8//6xp06bJZrOVarfZbHrllVd09OhR9e3b1w0VAgAAoK7wuNkYxo0bp1WrVmnp0qVav3697rvvPgUHB0uSDh8+rISEBJ09e1ZNmjTRM8884+ZqAQAA4E4eF3YbN26s+fPn6/nnn9ePP/6oRYsWyWQySZJcLpckqVOnTpo1a5YaN27szlIBAADgZh4XdiUpNDRUn376qbZu3aotW7aUuF1wz5491aNHDzdXCAAAgLrAI8NuoR49ehBsAQAAUK46f4Fafn6+RowYoV69eik5Ofmq6ycnJ8tqtWrUqFG1UB0AAADqsjofdhMSErRz50499NBDioiIuOr6ERERGjx4sL7//nutX7++FioEAABAXVXnw+7q1avl5eWlX/7ylxXe5le/+pVM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",
      "text/plain": [
       "<Figure size 732x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot = sns.displot(\n",
    "    data=pd.DataFrame(dict(Source=['Diffusion', 'FM', 'FDM', 'Dormand-Prince'], Data=range(4))),\n",
    "    x='Data',\n",
    "    hue='Source',\n",
    "    hue_order=['Diffusion', 'FM', 'FDM', 'Dormand-Prince'],\n",
    "    palette=[*sns.color_palette()[:3], 'tab:gray'],\n",
    ")\n",
    "sns.move_legend(\n",
    "    plot,\n",
    "    loc='upper center',\n",
    "    ncol=3 + 1,\n",
    "    title='',\n",
    "    bbox_to_anchor=(.455, 1.06),\n",
    "    frameon=True,\n",
    "    fancybox=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "649c383b-71d5-498e-b143-cbf713cea73f",
   "metadata": {},
   "outputs": [],
   "source": [
    "plots.save_all_subfigures(plot, f'event_histogram.conditional')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "82fd6df7-944a-4ac8-b1e9-d30dce4864a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# somehow, this line of code prevents a segmentation fault in nn.Dense\n",
    "# when calling model.init\n",
    "tf.config.experimental.set_visible_devices([], 'GPU')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "26f2a2a9-1783-4794-bfcb-8cf73dde97a5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<sqlalchemy.orm.session.SessionTransaction at 0x7f3ebcab3740>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "engine = cs.get_engine()\n",
    "cs.create_all(engine)\n",
    "session = cs.orm.Session(engine)\n",
    "session.begin()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b75026f0-0abb-4246-85ca-31761e3a13b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "config_alt_ids = {\n",
    "                          # ModelTrained, Ckpt, event conditioned, dataset\n",
    "    # ('18ntztqq', 'DM'): {}, # 0y35hp7d, epoch_1999, false, cs.DatasetLorenz\n",
    "    # ('l5b47ntl', 'FM'): {}, # 3bjjfgwa, epoch_1999, false, cs.DatasetLorenz\n",
    "    # ('7o8j9tfm', 'FM+Reg'): {}, # c0ijllm1, epoch_1999, false, cs.DatasetLorenz\n",
    "    # ('gmxd1fec', 'DM'): {}, # 0y35hp7d, epoch_1999, true, cs.DatasetLorenz\n",
    "    # ('8hxlur6u', 'FM'): {}, # 3bjjfgwa, epoch_1999, true, cs.DatasetLorenz\n",
    "    # ('vd5kgbat', 'FM+Reg'): {}, # c0ijllm1, epoch_1999, true, cs.DatasetLorenz\n",
    "    \n",
    "    ('c8kjccqy', 'DM'): {}, # jzke0dh6, epoch_1999, false, cs.DatasetFitzHughNagumo\n",
    "    ('mhgxsw66', 'FM'): {}, # trauw532, epoch_1999, false, cs.DatasetFitzHughNagumo\n",
    "    ('jnn5czst', 'FM+Reg'): {}, # 7io88gsu, epoch_1999, false, cs.DatasetFitzHughNagumo\n",
    "    ('ml7bscz4', 'DM'): {}, # jzke0dh6, epoch_1999, true, cs.DatasetFitzHughNagumo\n",
    "    ('tlrj9q8k', 'FM'): {}, # trauw532, epoch_1999, true, cs.DatasetFitzHughNagumo\n",
    "    ('hiyebupx', 'FM+Reg'): {}, # 7io88gsu, epoch_1999, true, cs.DatasetFitzHughNagumo\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "71d5b2f5-2d6d-4e50-bc64-f0799d351243",
   "metadata": {},
   "outputs": [],
   "source": [
    "cfgs = session.execute(sa.select(cs.Config).where(cs.Config.alt_id.in_([c[0] for c in config_alt_ids])))\n",
    "cfgs = {c.alt_id: c for (c,) in cfgs}\n",
    "reference_cfg = cfgs[next(iter(cfgs.keys()))]\n",
    "cfg_info = {}\n",
    "for k in config_alt_ids:\n",
    "    cfg = cfgs[k[0]]\n",
    "    assert cfg.rng_seed == reference_cfg.rng_seed\n",
    "    assert cfg.model.config.rng_seed == reference_cfg.model.config.rng_seed\n",
    "    assert cfg.model.config.dataset == reference_cfg.model.config.dataset\n",
    "    cfg_info[k] = dict(\n",
    "        cfg=cfg,\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "14e6d166-d85a-487e-acb4-dc6b729da54e",
   "metadata": {},
   "outputs": [],
   "source": [
    "key = jax.random.key(reference_cfg.rng_seed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f22b503a-c4e9-4838-8ff6-b1c21daedb76",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 6450/6450 [18:54<00:00,  5.68it/s]\n"
     ]
    }
   ],
   "source": [
    "key, key_dataset = jax.random.split(key)\n",
    "reference_cfg.model.config.dataset.batch_count_test = 64\n",
    "ds = datasets.get_dataset(reference_cfg.model.config.dataset, key=key_dataset)\n",
    "splits = datasets.split_dataset(reference_cfg.model.config.dataset, ds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bef17b90-bedb-422a-8f88-9dbd31ec1ad4",
   "metadata": {},
   "outputs": [],
   "source": [
    "constraint = event_constraints.get_event_constraint(reference_cfg.model.config.dataset)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "320f0ba1-f6ba-437a-89fb-141b1cf59f74",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_constraint_data = pd.DataFrame({'Source': 'Data', 'Constraint Value': constraint.constraint(splits['test'])})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8df89693-30f8-435f-8d22-90e92dde7e99",
   "metadata": {},
   "outputs": [],
   "source": [
    "for (_, source), info in cfg_info.items():\n",
    "    pred = np.load(info['cfg'].run_dir/cfg.prediction_filename)\n",
    "    info['df_constraint'] = pd.DataFrame({'Source': source, 'Constraint Value': constraint.constraint(pred)})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a26efdb8-4e72-43e4-986a-f057d41816c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "NUM_BINS = 128"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2c32586b-e33f-4603-aabb-daa5bcdba99d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL Divergence\n",
      "DM\n",
      "0.0260\n",
      "FM\n",
      "0.0280\n",
      "FM+Reg\n",
      "0.0280\n",
      "Total Variation\n",
      "DM\n",
      "0.0277\n",
      "FM\n",
      "0.0314\n",
      "FM+Reg\n",
      "0.0266\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_47029/3518656384.py:63: RuntimeWarning: divide by zero encountered in log\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
      "/tmp/ipykernel_47029/3518656384.py:63: RuntimeWarning: invalid value encountered in multiply\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n"
     ]
    },
    {
     "data": {
      "image/png": "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Z0Djlf7JlPMdj8d5+umngebPqJPddddd7Nixg6VLl3Ldddcl5zc2NrJgwQLuvvtuLr/8ckaOHAnAfffdR21tLf/7f//vVl9M1113XfJqkQwtnX1v3XTTTfzoRz9q1yj5gQceYNWqVbzwwgt84QtfAODWW2+ltraWqqoqrrvuug4bHv/nf/5nuxqYtm2zdOlSNmzYwHXXXce0adNSdly6kjMAvF4vRUVFABw92nHDzJKSEs4888zkhw4036o644wz2rXTkfTS1NTEypUr2/17/vnnO92muLiYkpISnn32WaLRKNB8vnNzc5k9e/ZghS59MFTP94svvsiDDz7Igw8+yJ133snnP/95XnnlFSZMmJD81Q7NjZKff/55zjvvvFYJDjS347jllluIRqOUlZUBEI1Gef7558nPz+db3/pWq/WnTJnCl770pQE/Nkm9zr63Ro8e3WGvq2uvvRaAV155pVePU1xc3K7DjWEYXHPNNX3aX3d0JWeAdFfc3TAM5s+fz3/913/x97//HYCqqipuu+22tO3OKM1OPfVUXnrppV5vd9VVV/Hd736XF198kRkzZlBeXs68efPIycnhyJEjAxCppMJgnu8DBw5w2WWd9wzrqEv7smXLmDdvXrv5//3f/81///d/t9v+iSeeoKCgIDnv3XffxbIsEolEh1esWmLds2cPANXV1YTDYT7xiU+Ql5fXbv0ZM2Z02B5J0l9H31uxWIynnnqK559/nt27d9PY2NhqvYMHD/bqMZqamnj00UfZvHkzNTU1BIOte2T3dn/dUZIzACKRSLKtzbBhwzpdb+7cuaxYsSJ5Ncftdnf4YSWZYdasWRQVFfH000+zb98+4vG4bk1msL6c74KCAm655ZZ28zdu3Eh9fX27Ky0AU6dO7XBfd911F1dddRWJRILa2lp++ctf8vTTT3Pbbbfx0EMP4XI1X8hv+ax69913O2yQ3KLly6ihoQGg0x44mdQzJ5t09r21ePFiXnzxRcaOHcusWbMYMWJEsjjmypUrk1cqeyIWi3Httdfy3nvvMWXKFObMmcMpp5yC2+2mvr6e3/zmN73aX08oyRkAb731FvF4nBEjRnQ5GNKoUaO49NJLk5e9L730UkaNGjVYYcog83q9zJkzhyeffJKdO3cyefJkzj33XKfDkgHSl/NdUFDQYTffN954A6BXXdlbuFwuiouL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nFP49d9+RjxhqRp5OgkGySkqYgYq6yAi6UNJjqSl1eX3URAoxDTbv0SPBY9q5GMREemWkhxJS3VNR7q566HbVmklJ4dgbS07d+7kLJV1EJE0oTY5MiTl+fL4U/XT/Kn6aadDEWgu5VBUhJWfr7IOIpI2lOSkgSeffJLPfvaznHPOOVx11VX8/e9/dzqktOcyPVTtruS9ne85HYqIiKQpJTkO27RpE8uWLePmm29m48aNTJkyhRtuuIHDhw87HVrai1txLEuj66aFaBTPT37Cx1avVlkHEUkbSnIc9sgjj/CVr3yF+fPnM3HiRO644w78fj/PPPOM06ENCabppby8nLKyMqdDyW6xGJ677+b0hx5SWQcRSRtqeNyNZ599lq1bt7J9+3Z27NhBJBLhlltu4dZbb+10m6qqKlauXMmbb75JKBSiuLiYuXPnsnDhQtzuE095NBrl/fff56abbkrOc7lcXHTRRWzbtm1AjytT5PryqOItLHecWcxyOpzs5XYTu/FGjh49Sp5bHysikh70adSNFStWUFtbS2FhIaeeeir79u3rcv2tW7eyaNEiLMviiiuuYNSoUZSXl3PPPfewbds2Vq5ciXG8YebRo0exLIvhw4e32sfw4cPZs2fPgB1TpmkM16tLudN8PmL338/+ykqm+nxORyMiAuh2VbfuuusuXnzxRd544w2+/e1vd7muZVksXbqUcDjMqlWruOeee1iyZAkbNmzgk5/8JJs3b6a0tHSQIhcREcluSnK6cdFFFzFmzJgerbtlyxaqq6spKSlh5syZyfler5fFixcDsHbt2uT8U045BdM02zUyPnz4MCNGjEhB9CIiItlLSU4KbdmyBYCLL7643bIZM2aQk5PD22+/TfR47xOv18vZZ5/Na6+9llwvkUjw2muvMW3atMEJOmNobBZHNTURKCxkekkJNDU5HY2ICKA2OSlVXV0NwJlnntlumWmajBkzhp07d7J//34mTJgAwKJFi/je977HJz7xCc4991wee+wxQqEQ8+bN63Mctm0TDAb7vP1gCIVCraYnMwwD0zQxXQamy8Ttdif/39m0IFDIw68+QCJu8Y1PfQtbRSIHVzBITry5XVQoFII0f/1J97p6j54sRyNcSxpTkpNCjY2NAOTn53e4PPd40cL6+vrkvNmzZ3PkyBEeeOABDh06xNSpU/nVr37Vr9tV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",
      "text/plain": [
       "<Figure size 550.75x540 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "infos = {\n",
    "    k: info for k, info in cfg_info.items()\n",
    "    if not info['cfg'].model.sample_event_conditioned\n",
    "}\n",
    "df = pd.concat([\n",
    "    info['df_constraint'] for info in infos.values()\n",
    "], ignore_index=True)\n",
    "bins_plot = np.histogram(np.zeros(2), bins=NUM_BINS, range=pd.concat((df, df_constraint_data))['Constraint Value'].agg(['min', 'max']))[1]\n",
    "data_color = 'tab:gray'\n",
    "plot = (\n",
    "    sns.displot(\n",
    "        data=df,\n",
    "        stat='density',\n",
    "        x='Constraint Value',\n",
    "        row='Source',\n",
    "        row_order=[c[1] for c in infos],\n",
    "        hue='Source',\n",
    "        hue_order=[*(c[1] for c in infos), 'Data'],\n",
    "        palette=[*sns.color_palette()[:len(infos)], data_color],\n",
    "        common_norm=False,\n",
    "        bins=bins_plot,\n",
    "        facet_kws=dict(\n",
    "            # sharey=False,\n",
    "        ),\n",
    "        height=1.8,\n",
    "        aspect=2.2,\n",
    "    )\n",
    "    .set(yscale='log' if isinstance(reference_cfg.model.config.dataset, cs.DatasetFitzHughNagumo) else 'linear')\n",
    "    .set_titles('')\n",
    ")\n",
    "plot.map(\n",
    "    sns.histplot,\n",
    "    data=df_constraint_data,\n",
    "    bins=bins_plot,\n",
    "    stat='density',\n",
    "    color=data_color,\n",
    "    x='Constraint Value',\n",
    "    zorder=-1,\n",
    ").set_xlabels('').set_ylabels('')\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    ax = plot.axes[row][col]\n",
    "    ax.axvline(x=0, c='r', ls=':')\n",
    "    ax.xaxis.set_tick_params(labelbottom=True)\n",
    "    ax.yaxis.set_tick_params(labelleft=True)\n",
    "    if row != len(plot.row_names) - 1:\n",
    "        ax.xaxis.set_tick_params(labelbottom=False)\n",
    "plot.tight_layout()\n",
    "sns.move_legend(\n",
    "    plot,\n",
    "    loc='upper center',\n",
    "    ncol=len(cfg_info) + 1,\n",
    "    title='',\n",
    "    bbox_to_anchor=(.455, 1.06),\n",
    "    frameon=True,\n",
    "    fancybox=True,\n",
    ")\n",
    "data_hist, bins_kl = np.histogram(df_constraint_data['Constraint Value'], bins=NUM_BINS, range=df_constraint_data['Constraint Value'].agg(['min', 'max']))\n",
    "data_hist = data_hist / len(df_constraint_data)\n",
    "print('KL Divergence')\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    print(plot.row_names[row])\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_kl)[0] / len(data)\n",
    "    kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
    "    print(f'{kl_divergence.sum():.4f}')\n",
    "    \n",
    "print('Total Variation')\n",
    "data_hist, bins_tv = np.histogram(df_constraint_data['Constraint Value'], bins=NUM_BINS, range=df_constraint_data['Constraint Value'].agg(['min', 'max']), density=True)\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    print(plot.row_names[row])\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_tv, density=True)[0]\n",
    "    total_variation = 0.5 * np.abs(model_hist - data_hist) * np.diff(bins_tv)\n",
    "    print(f'{total_variation.sum():.4f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "786505d2-c9c2-4f57-aa67-f7219cbc9e95",
   "metadata": {},
   "outputs": [],
   "source": [
    "plots.save_all_subfigures(plot, f'event_histogram.unconditional.{reference_cfg.model.config.dataset.__class__.__name__}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "b41ce2a8-3948-4a7e-beef-83fd1238d706",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_47029/2440675782.py:6: RuntimeWarning: divide by zero encountered in log\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
      "/tmp/ipykernel_47029/2440675782.py:6: RuntimeWarning: invalid value encountered in multiply\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABLQAAAGWCAYAAABhB9o5AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA5SJJREFUeJzs3XecG/WZP/DPqEvbq9vaXjdsAwbjCgng5DCEnmAgIaHE5Lg0IA7JJSGBSw/8cnBHOPDFIYV+IZgWAgYbEzDdNq64rsuu7bW93r4rrdpoZn5/TNGM+tq7q931551XXmal0cxXX0kj6dHzPF9BURQFREREREREREREQ4Qt3wMgIiIiIiIiIiLqDQa0iIiIiIiIiIhoSGFAi4iIiIiIiIiIhhQGtIiIiIiIiIiIaEhhQIuIiIiIiIiIiIYUBrSIiIiIiIiIiGhIYUCLiIiIiIiIiIiGFAa0iIiIiIiIiIhoSHHkewBERJRfoihCkqR8D4OIiIYgu90Op9OZ72EQEdFJiAEtIqKTVHd3N1pbWxGJRPI9FCIiGsLcbjcqKytRXFyc76EQEdFJhAEtIqKTUHd3Nw4fPozCwkJUVlbC6XRCEIR8D4uIiIYQRVEgiiK6urpw+PBhAGBQi4iIBoygKIqS70EQEdHA2r9/P5xOJ2pqahjIIiKiE6IoChobGyGKIiZOnJjv4RAR0UmCTeGJiE4yoigiEomgpKSEwSwiIjphgiCgpKQEkUgEoijmezhERHSSYECLiOgkozeAZxNfIiLqK/p7ChcZISKigcKAFhHRSYrZWURE1Ff4nkJERAONAS0iIiIiIiIiIhpSGNAiIiIiIiIiIqIhhQEtIiIiIiIiIiIaUhz5HgAREVG+TJ061fK30+lEYWEhRo0ahVNPPRUXXXQRzj33XNjt9qTb3nnnnXjxxRcBAN/73vfwjW98I+Ux/vjHP+L+++8HAFx11VX4f//v//XxvaDjlfj4J1q6dCkWLlwIAHjooYfw8MMPAwC+9KUv4Ze//GXK26xYsQJ33HEHAGDevHl48skn+3DEdCKG4uNtHofO5XJh5MiROPvss/GNb3wDNTU1fXpMIiKioYIBLSIiOqkVFBTg5ptvBgDEYjH4/X7s2bMHL730Ep577jmcfvrpuP/++zFhwoSUt3c4HHj++efx9a9/PWVT5Oeeew4OhwOxWKxf7wcdH/PjnyjVY+5wOPDqq6/izjvvhM/nS7p++fLlfLwHsaH6eH/2s5/FaaedBgBob2/Hhx9+iGeffRYrV67Es88+i9ra2n49PhER0WDEgBYREZ3UCgsLcfvttydd3tzcjF/96ldYtWoVbr75Zjz//POoqKhI2u7888/HP//5T6xduxZnn3225bp169ahoaEBCxcuxOrVq/vtPtDxS/f4p6M/3q+99hquvvpqy3WNjY348MMPccEFF/DxHqQGw+N944034vDhw/jnP/+Z820uuOACXHvttcbfkiTh61//Ot577z384Q9/wL333pvzvoiIiIYL9tAiIiJKobq6Gr/73e8wb948HD16FMuWLUu53ZVXXgm3243ly5cnXbd8+XK4XC58/vOf7+/h0gBZsGABqqurUz7ezz33HBRFsQQeaGgbrI+33W7HNddcAwD45JNPkq4PBoNYunQprrjiCpx55pmYNWsWbrzxRqxZsybl/pqbm/HjH/8Y55xzDs444wx8/vOfx4svvoi1a9di6tSpeOihh/r1/hARER0PBrSIiIjSsNvt+Pa3vw0AePXVV6EoStI2JSUluPDCC/HGG2+gq6vLuLy7uxsrV67EhRdeiJKSkgEbM/Uvu92ORYsWYdOmTdi3b59xuSRJeOGFFzBz5kxMnjw5jyOkvjSYH2/9fORwWAsuurq6cN111+F//ud/4PF48MUvfhGXX345Dhw4gK9//ev461//atm+ra0N1113HV544QVMnjwZX/3qV3HqqafiF7/4BZ544okBuz9ERES9xZJDIiKyUBQFiIr5HkZmLmfKflX9Yfbs2XA4HGhra0NjYyPGjh2btM21116LV155BS+//DJuvPFGAMDLL7+MSCQy5LJ1FEWBHAvnexgZ2RyePnv8A4FAyuyTiRMn4rLLLkt5m2uuuQZ/+MMfsHz5ctx5550AgHfeeQfHjh3Dd77znT4Z10BRFAURaXA/3m47H+9EsVgMzz33HAD1HGX261//Grt378ZPfvITfPWrXzUuDwQCuPHGG3HPPfdg4cKFqKqqAgD813/9Fw4fPox/+7d/w7//+78b23/1q181ssCIiIgGIwa0iIjIoCgKog/9H5SGw/keSkbChDFw3faVAQlquVwulJaWorW1FR0dHSkDWvPnz8f48ePx3HPPGQGt5cuXY9y4cTj77LOxbt26fh9nX1AU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Bh+ew08+nKPMOD+ZcX76z4A3hZ8wYQIA4MCBA0nXSZKExsZG2O32rH2mamtr0+6npaUFwWAQI0eONCKh48aNg91uR2NjIyRJSrqNvh99v6nozeAvueSSrAG3VMrKygBgWNTcExER9RdFjqn/Ksnv10REREREQB4CWvPnzwcAvPfee0nXbdiwAcFgEDNnzoTL5cq4n7PPPjvtfvTL5s2bZ1zmdrtx5plnIhgMYuPGjUm3effddy3jS0VvBp+p3DCTrVu3AgBqamqO6/ZEREQnA0US1X9lBrSIiIiIKLW8BLRqa2uxdu1arFmzxrg8Go3iwQcfBABcd911xuWhUAj79u3DkSNHLPu5+OKLUVpaildeecXSlNHv92PZsmUAklch1Pf74IMPIhqNGpevWbMG69atw4QJEyxBMLOPP/4Y+/bty9gMHgB2794NURSTLl+3bh0ee+wxAMAVV1yR9vZEREQnO9nI0IrleSRERERENFgNeA8tu92Oe++9F4sXL8att96KSy+9FFVVVVizZg327NmDhQsXWgI+W7duxU033YR58+bhySefNC4vKirCL37xC9xxxx24/vrrcdlll6GgoACrVq3C4cOHceONN2LOnDmWY1955ZVYuXIl3nzzTSxatAgLFixAS0sLVqxYAbfbjXvuuQd2uz3luHNpBg8Ajz76KN5++23Mnj0bo0aNgt1ux549e/D+++8DAL797W8njYuIiIjijJJDZmgRERERURp5WeVw1qxZePbZZ/HQQw9hzZo1CAaDGDt2LH7wgx9g8eLFEAQhp/1cfPHFKC8vx7Jly7BixQrEYjFMmjQJ3/rWt3DNNdckbS8IAh588EE8/vjjeOGFF/DEE0/A5/NhwYIF+M53voOpU6emPE5XVxdWrlyZUzP4hQsXIhAIYNeuXfjggw8giiLKyspw0UUX4Stf+QrOOeecnO4bERHRyUqWRe1fZmgRERERUWp5CWgBwLRp07B06dKs282fPx+7d+9Oe/28efPSlgmm4nQ6ccstt+CWW27J+TYlJSVG/6tsFi5ciIULF+a8byIiIrJihhYRERERZTPgPbSIiIiIMpElrnJIRERERJkxoEVERESDCjO0iIiIiCgbBrSIiIhoUIkHtNhDi4iIiIhSY0CLiIiIBhW9KbyiMKBFRERERKkxoEVERESDirnkUFGUPI+GiIiIiAYj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iIgSTjD4m8KzhxYRERERdQMDWkRERJRwgmDyf2VAi4iIiIjix4AWERERJZzSO8vAWxEiIiIiih/vIomIiCjhAk3hTUm+EiIiIiIaiBjQIiIiooRTmsJzlUMiIiIi6gbeRRIREVHCKRlaXOWQiIiIiLqBAS0iIiJKODkzi03hiYiIiKg7GNAiIiKihGOGFhERERH1BANaRERElHDsoUVEREREPcG7SCIiIkq4QECLGVpEREREFD8GtIiIiCjhWHJIRERERD3BgBYRERElHksOiYiIiKgHeBdJRERECWdghhYRERER9QADWkRERJR4cmYWe2gRERERUTcwoEVEREQJJ2dmGRjQIiIiIqJuYECLiIiIEk5Z3dDAWxEiIiIiih/vIomIiCjhBKUpvCnJV0JEREREA1HC7yJFUcQ777yD9evX4/Tp0zCbzRg3bhwWLFiA8vLyuI7l8XiwZs0abNmyBefOnYPNZkN5eTkWLVqEsrKysM9pbGxETU0N9u3bh9bWVowYMQIzZszAggULYLVaNfs+++yz2LJli+413HLLLaitrVV+3rx5M5577rmI+//ud7/D7bffHserJCIiuvoI/swsrnJIRERERN2R8IDWSy+9hHXr1qGgoABVVVXo6OjAtm3bUF1djddeew3Tpk2L6TiiKGLx4sXYuXMnRo4cierqajQ1NWHHjh3Ys2cPVq9ejRtvvFHznDNnzqCqqgotLS246667UFJSgsOHD2PVqlX461//itraWqSmpir7T506FQUFBWHP/+6776KhoSFicOrOO+/EmDFjQraXlJTE9PqIiIiuZnJmFlc5JCIiIqLuSGhA68iRI1i3bh3sdjveeecdZGRkAAAefvhhPPTQQ3j++ecxZcoUpKenRz3We++9h507d6K8vBxvvfUWLBYLAGDmzJl47LHHsHTpUmzduhVGY+BGedmyZbh8+TKWLVuGH/zgBwCkwNiSJUuwbds2rF69GgsXLlT2nzp1KqZOnRpy7ra2Nvz7v/87zGYz7rvvvrDXN3XqVMyePTv2wSEiIhpE5MwsgU3hiYiIiKgbEprnv2HDBgDAwoULlWAWAIwZMwYzZ85ES0sLduzYEdexFi9erASzAKCyshIVFRU4ffo0Dh06pGw/e/YsDhw4gKKiIlRVVSnbBUHAkiVLAAAbN26EKIpRz/3uu++is7MTd999N3Jz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",
      "text/plain": [
       "<Figure size 1414.75x420 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins_kl = np.histogram(np.zeros(2), bins=NUM_BINS, range=df_constraint_data['Constraint Value'].agg(['min', 'max']))[1]\n",
    "data_hist = np.histogram(df_constraint_data['Constraint Value'], bins=bins_kl)[0] / len(df_constraint_data)\n",
    "df_kls = []\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_kl)[0] / len(data)\n",
    "    kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
    "    df_kl = pd.DataFrame({'Source': plot.row_names[row], 'Bins': bins_kl[:-1], 'KL Divergence': kl_divergence})\n",
    "    df_kls.append(df_kl)\n",
    "df_kl = pd.concat(df_kls, ignore_index=True)\n",
    "plot_kl = (\n",
    "    sns.relplot(\n",
    "        kind='line',\n",
    "        data=df_kl,\n",
    "        x='Bins',\n",
    "        y='KL Divergence',\n",
    "        col='Source',\n",
    "        col_order=[c[1] for c in infos],\n",
    "        hue='Source',\n",
    "        hue_order=[*(c[1] for c in infos)],\n",
    "        palette=[*sns.color_palette()[:len(infos)]],\n",
    "        facet_kws=dict(\n",
    "            # sharex=False,\n",
    "        ),\n",
    "        height=4.2,\n",
    "        aspect=1,\n",
    "    )\n",
    "    # .set(yscale='log' if isinstance(reference_cfg.model.config.dataset, cs.DatasetFitzHughNagumo) else 'linear')\n",
    "    .set_titles('')\n",
    "    .set_xlabels('')\n",
    "    .set_ylabels('')\n",
    ")\n",
    "sns.move_legend(\n",
    "    plot_kl,\n",
    "    loc='upper center',\n",
    "    ncol=len(cfg_info),\n",
    "    title='',\n",
    "    bbox_to_anchor=(.455, 1.06),\n",
    "    frameon=True,\n",
    "    fancybox=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "9b838e5f-17ed-4dbc-b076-af849f0047ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL Divergence\n",
      "DM\n",
      "0.3011\n",
      "FM\n",
      "0.3468\n",
      "FM+Reg\n",
      "0.2084\n",
      "Total Variation\n",
      "DM\n",
      "0.1192\n",
      "FM\n",
      "0.2164\n",
      "FM+Reg\n",
      "0.1168\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_47029/14887829.py:64: RuntimeWarning: divide by zero encountered in log\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
      "/tmp/ipykernel_47029/14887829.py:64: RuntimeWarning: invalid value encountered in multiply\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n"
     ]
    },
    {
     "data": {
      "image/png": "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xPHjxykrK+O5555rfNyQn58PtD+AYVOJ2psTJ04k3d7WeslsyX633nvvPV577TWmTp3KmjVrmj22OnbsWKtBJzvy2muvsXPnTm666SYefvjhZtu2b9/eI43W1SYnzUzT5D//8z8BGhtjtWfOnDnU1dVRV1env+r7gS9/+cvE43GOHTum690PZNr1/s53voPL5WL16tWN48JceeWVOBwO3n333Q4fs0NDg2uv18uePXuSji1TUVGR9rilZ7X1u3Xo0CEAPvOZz7Rql/POO+8kLStRQxiPx1ttS5SXGCW8M+WlSklOGh07dox//dd/5e233+bCCy9sc9qGpj7zmc+wevVqVq9ezbRp03ohSrHTuHHjWLNmDatXr27WrVKyU6Zd74svvpjZs2dz+vRpfv7znwMwePBgPv/5z1NZWcmqVauS/jjt3bu3sYbG7XYzY8YMzp4922pMlcrKSn7961/3+PuQ9Gnvd2v48OEAvP32282Oqamp4Qc/+EHS8hLDnxw9erTVtrbKq6ysZM2aNd1/E+3Q46puaNql1DRNzp49y969e9m+fTvRaJSrrrqKRx99tN32OAmGYSTNaiV7KZntXzLtei9YsIBf//rXPP3009x6660MHDiQ7373u1RVVbFq1SpeeeUVJk6cyHnnncf//M//sHfvXvbs2cN//dd/Nba3+da3vsVf/vIXnnzySd59910mTJjA8ePH+d3vfse0adPYsmWLOlBkmO78bl155ZVMmDCB3//+9/zjP/4jEyZM4NixY/zxj3/kb/7mbzhy5Eir83zqU5/i5z//Of/n//wfrr/+enw+HxdeeCFf+tKX+MxnPkNRURE///nP2bdvH2PHjuXIkSO8/vrrfPazn+W///u/0/6+05rkOHL9aZ9CIR0cua3nj0lFokspNEx0lpuby/Dhw/nSl77UONFZosquP3F7C+0OIalMjauvK/CcZ3cISWVqXJli2LBh/OM//iNPP/00a9as4d5776WgoIDnn3++sRfN7373O6LRKEOGDOGSSy7hq1/9KpdeemljGYMHD+aFF17ghz/8IWVlZbz77ruMHDmS7373u/h8PrZs2ZK051Wmys3NtTuEVtIdU3d+twzD4Mc//jE/+tGPKCsrY+fOnQwfPpyvf/3rfP3rX0+alEybNo3Fixezbt06nnrqKaLRKJMnT+ZLX/oSubm5PPPM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",
      "text/plain": [
       "<Figure size 550.75x540 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "infos = {\n",
    "    k: info for k, info in cfg_info.items()\n",
    "    if info['cfg'].model.sample_event_conditioned\n",
    "}\n",
    "df = pd.concat([\n",
    "    info['df_constraint'] for info in infos.values()\n",
    "], ignore_index=True)\n",
    "df_constraint_event_data = df_constraint_data.loc[df_constraint_data['Constraint Value'] > 0]\n",
    "data_color = 'tab:gray'\n",
    "plot = (\n",
    "    sns.displot(\n",
    "        data=df,\n",
    "        stat='density',\n",
    "        x='Constraint Value',\n",
    "        row='Source',\n",
    "        row_order=[c[1] for c in infos],\n",
    "        hue='Source',\n",
    "        hue_order=[*(c[1] for c in infos), 'Data'],\n",
    "        palette=[*sns.color_palette()[:len(infos)], data_color],\n",
    "        common_norm=False,\n",
    "        bins=bins_plot,\n",
    "        facet_kws=dict(\n",
    "            # sharex=False,\n",
    "        ),\n",
    "        height=1.8,\n",
    "        aspect=2.2,\n",
    "    )\n",
    "    .set(yscale='log' if isinstance(reference_cfg.model.config.dataset, cs.DatasetFitzHughNagumo) else 'linear')\n",
    "    .set_titles('')\n",
    ")\n",
    "plot.map(\n",
    "    sns.histplot,\n",
    "    data=df_constraint_event_data,\n",
    "    bins=bins_plot,\n",
    "    stat='density',\n",
    "    color=data_color,\n",
    "    x='Constraint Value',\n",
    "    zorder=-1,\n",
    ").set_xlabels('').set_ylabels('')\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    ax = plot.axes[row][col]\n",
    "    ax.axvline(x=0, c='r', ls=':')\n",
    "    ax.xaxis.set_tick_params(labelbottom=True)\n",
    "    ax.yaxis.set_tick_params(labelleft=True)\n",
    "    if row != len(plot.row_names) - 1:\n",
    "        ax.xaxis.set_tick_params(labelbottom=False)\n",
    "plot.tight_layout()\n",
    "sns.move_legend(\n",
    "    plot,\n",
    "    loc='upper center',\n",
    "    ncol=len(cfg_info) + 1,\n",
    "    title='',\n",
    "    bbox_to_anchor=(.455, 1.06),\n",
    "    frameon=True,\n",
    "    fancybox=True,\n",
    ")\n",
    "\n",
    "print('KL Divergence')\n",
    "data_hist, bins_kl = np.histogram(df_constraint_event_data['Constraint Value'], bins=NUM_BINS, range=df_constraint_event_data['Constraint Value'].agg(['min', 'max']))\n",
    "data_hist = data_hist / len(df_constraint_event_data)\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    print(plot.row_names[row])\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_kl)[0] / len(data)\n",
    "    kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
    "    print(f'{kl_divergence.sum():.4f}')\n",
    "    \n",
    "print('Total Variation')\n",
    "data_hist, bins_tv = np.histogram(df_constraint_event_data['Constraint Value'], bins=NUM_BINS, range=df_constraint_event_data['Constraint Value'].agg(['min', 'max']), density=True)\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    print(plot.row_names[row])\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_tv, density=True)[0]\n",
    "    total_variation = 0.5 * np.abs(model_hist - data_hist) * np.diff(bins_tv)\n",
    "    print(f'{total_variation.sum():.4f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "801935ed-8fe1-4ac6-901d-99dcad243e71",
   "metadata": {},
   "outputs": [],
   "source": [
    "plots.save_all_subfigures(plot, f'event_histogram.conditional.{reference_cfg.model.config.dataset.__class__.__name__}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a7379ec5-09b1-4bca-9d97-57b006fa96ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_47029/1416192705.py:6: RuntimeWarning: divide by zero encountered in log\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
      "/tmp/ipykernel_47029/1416192705.py:6: RuntimeWarning: invalid value encountered in multiply\n",
      "  kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n"
     ]
    },
    {
     "data": {
      "image/png": "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4h6DWEREREREREREFPcYxCIiIiIiIiIiorjHIBYREREREREREcU9BrGIiIiIiIiIiCjuMYhFRERERERERERxj0EsIiIiIiIiIiKKewxiERERERERERFR3GMQi4iIiIiIiIiI4h6DWEREREREREREFPcYxCIiIiIiIiIiorjHIBYREREREREREcU9BrGIiIiIiIiIiCjuMYhFRERERERERERxj0EsIiIiIiIiIiKKewxiERERERERERFR3GMQi4iIiIiIiIiI4h6DWEREREREREREFPcYxCIiIiIiIiIiorjHIBYREREREREREcU9BrEi6ODBgzh48GBvD4OIiKKA53giouTG8zwRUfxjECuCnE4nnE5nj27rcDiwdetWOByOCI+KvDjH0cX5jT7Oce8K5xwP8PGLNs5v9HGOo4vz2/v4Xj6+cY6ji/MbfZzjyGAQK07Ishz0kyKPcxxdnN/o4xwnNj5+0cX5jT7OcXRxfhMbH7/o4xxHF+c3+jjHkcEgFhERERERERERxT0GsYiIiIiIiIiIKO4xiEVERERERERERHGPQSwiIiIiIiIiIop7DGIREREREREREVHcYxCLiIiIiIiIiIjiHoNYREREREREREQU9xjEIiIiIiIiIiKiuKfrrTs+cOAAFi1ahC1btsBmsyE/Px833ngj5syZA52ua8P617/+hb1792L//v04fPgwXC4XnnvuOdx0003t3sbtduP111/H+++/j+PHj8NsNuOiiy7CL3/5S4wZMyZSh0dERERERERERBHUK0Gsbdu2Ye7cuZBlGddccw1yc3NRXFyMBQsWYPv27Vi0aBEkSep0P08//TQAoH///hgwYABOnjzZ4fWFEJg3bx7Wr1+P0aNH44477kBNTQ0+/vhjfPnll/jnP/+JSZMmReQYiYiIiIj6IiEEFLcdWr2pt4dCRERJJublhLIs45FHHoHdbsfixYuxYMECzJ8/H++99x4uvPBCrF+/HitXruzSvl566SV88cUX+Prrr3HzzTd3ev0PP/wQ69evx0UXXYT33nsP8+fPx4IFC7B48WLY7XY8+uijkGU53EMkIiIiIuqzDn3zZxS/8T001x/t7aEQEVGSiXkQq6SkBGVlZSgqKsLUqVN92w0GA+bNmwcAWLZsWZf2dcUVV2DgwIFdvm/vfufNmweDweDbPnXqVBQWFuLo0aPYvHlzl/dHRERERETBGk7tgCI7YTl9oLeHQkRESaZXglgAMGXKlDaXTZ48GWazGTt27IDT6Yzo/TocDuzcuRNmszlkyeBll10WND4iIiIiIuo+2WX3/LT28kiIiCjZxLwnVllZGQBg2LBhbS7TarXIy8tDaWkpKioqMHLkyIjd7/HjxyHLMvLy8qDVattc7h1PeXl5WPcjhIDV2v0XbJvNFvSTIo9zHF2c3+jjHHfObDZHdf89PccDfPyijfMbfZzj6Eqm+XU7WwAAtpbGHp8zQ4n2OR7ge/l4xjmOLs5v9HGOO9eV83zMg1jNzc0AgPT09JCXp6amAgCampoier8WiwUAkJaWFvJy73bv9XrK5XJh//79Pb59uEE06hznOLo4v9HHOW7f5MmTo7r/cM/xAB+/aOP8Rh/nOLqSYX6dDvX9/qmTx9GkCe+cGSja53iA7+UTAec4uji/0cc5bl9XzvO9sjphMtPr9Rg1alS3b2ez2VBeXo6CggKYTFzJJRo4x9HF+Y0+znHv6+k5HuDjF22c3+jjHEdXMs3vpu1OCADZ/dJQMG5cbw+nW/hePn5xjqOL8xt9nOPIiHkQq7OMp5YWNf04IyMjovfrzfzyZoK11lmGWFdJkhRWqrPJZIpJqnRfxjmOLs5v9HGOe0+453iAj1+0cX6jj3McXYk+v0KRochqb1tJOBPuWPhePv5xjqOL8xt9nOPwxLyx+/DhwwEAx44da3OZLMuorKyEVqtFfn5+RO936NCh0Gq1qKyshCzLbS73jqegoCCi90tERERE1FfIbrv//2zsTkREERbzIFZRUREAYOPGjW0u27p1K6xWKyZOnAiDwRDR+zUajTj//PNhtVqxbdu2Npd/+eWXQeMjIiIiIqLuCQxcuV1sXkxERJHVK0GsgoIClJSUoLi42Lfd6XRi4cKFAIBZs2b5tttsNhw5cgQnTpwI+769+124cCGcTqdve3FxMTZv3ozhw4ejsLAw7PshIiIiIuqLmIlFRETRFPOeWFqtFs899xzmzJmD+++/H9OnT0dOTg6Ki4tx6NAhXHXVVbjuuut819+1axfuuOMOFBYW4s033wza18svv4yjR48CgG8VkeXLl2Pz5s0A1M72t9xyi+/6119/PdauXYtPP/0UN910E6ZOnYra2lqsXr0aRqMRzz77LLRabbSngIiIiIgoKQUGrhjEIiKiSOuV1QknTZqEd999Fy+++CKKi4thtVqRn5+P+fPnY86cOZAkqUv7+fLLL30BK69t27YFlQsGBrEkScLChQvxxhtv4L333sPSpUthNpsxdepU/OpXv8KYMWMic4BERERERH2Q7PaXEDKIRUREkdYrQSwAGDt2LBYvXtzp9YqKinDw4MGQl7XOzOoKvV6Pu+66C3fddVe3b0tERERERO2TA/pgud0MYhERUWTFvCcWERERERElp8AglszG7kREFGEMYhERERERUUQElxO2QAjRi6MhIqJkwyAWERERERFFRGAfLKHIEIqrF0dDRETJhkEsIiIiIiKKiMBMLABws7k7ERFFEINYREREREQUEbLL3up3BrGIiChyGMQiIiIiIqKIaB20YhCLiIgiiUEsIiIiIiKKiNblhFyhkIiIIolBLCIiIiIiigi3iz2xiIgoehjEIiIiIiKiiGibidXSSyMhIqJkxCAWERERERFFhOJiOSEREUUPg1hERERERBQRbrenfFBSP2awsTsREUUSg1hERERERBQRsssOADCk9APQtkcWERFROBjEIiIiIiKiiPBmXhlM2Z7f2ROLiIgih0EsIiIiIiKKCG9jd4O5v/o7M7GIiCiCGMQiIiIiIqKI8AaxjL4gFntiERFR5DCIRUREREREYRNC+DKvDCY1iOVr9E5ERBQBDGIREREREVHYFNkJCAVAQDmhk0EsIiKKHAaxiIiIiIgobIGlg77G7szEIiKiCGIQi4iIiIiIwia77QAAjdYAvSFd3cbG7kREFEEMYhERERERUdi8Td21ehO0ejMAwM3G7kREFEEMYhERERERUdi85YRanT+IxdUJiYgokhjEIiIiIiKisHlLB9UglsmzjUEsIiKKHAaxiIiIiIgobL4glt4MnT7Vt00I0ZvDIiKiJMIgFhERERERhc3fEyvFl4klhAxFdvTmsIiIKIkwiEVERERERGHzBbF0Zmh1Jv92rlBIREQRwiAWERERERGFzdfYXW+CpNFCozMGbSciIgoXg1hERERERBQ22WUHAF8Wlr8vFoNYREQUGQxiERERERFR2Pw9sUxBP90MYhERUYQwiEVERERERGHzlRN6MrG0OnPQdiIionAxiEVERERERGFrm4nlDWKxsTsREUWGrrfu+MCBA1i0aBG2bNkCm82G/Px83HjjjZgzZw50uq4P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",
      "text/plain": [
       "<Figure size 1414.75x420 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins_kl = np.histogram(np.zeros(2), bins=128, range=df_constraint_event_data['Constraint Value'].agg(['min', 'max']))[1]\n",
    "data_hist = np.histogram(df_constraint_event_data['Constraint Value'], bins=bins_kl)[0] / len(df_constraint_event_data)\n",
    "df_kls = []\n",
    "for (row, col, hue), data in plot.facet_data():\n",
    "    model_hist = np.histogram(data['Constraint Value'], bins=bins_kl)[0] / len(data)\n",
    "    kl_divergence = np.where(data_hist == 0., 0., data_hist * np.log(data_hist / (model_hist + 1e-12)))\n",
    "    df_kl = pd.DataFrame({'Source': plot.row_names[row], 'Bins': bins_kl[:-1], 'KL Divergence': kl_divergence})\n",
    "    df_kls.append(df_kl)\n",
    "df_kl = pd.concat(df_kls)\n",
    "plot_kl = (\n",
    "    sns.relplot(\n",
    "        kind='line',\n",
    "        data=df_kl,\n",
    "        x='Bins',\n",
    "        y='KL Divergence',\n",
    "        col='Source',\n",
    "        col_order=[c[1] for c in infos],\n",
    "        hue='Source',\n",
    "        hue_order=[*(c[1] for c in infos)],\n",
    "        palette=[*sns.color_palette()[:len(infos)]],\n",
    "        facet_kws=dict(\n",
    "            # sharex=False,\n",
    "        ),\n",
    "        height=4.2,\n",
    "        aspect=1,\n",
    "    )\n",
    "    # .set(yscale='log' if isinstance(reference_cfg.model.config.dataset, cs.DatasetFitzHughNagumo) else 'linear')\n",
    "    .set_titles('')\n",
    "    .set_xlabels('')\n",
    "    .set_ylabels('')\n",
    ")\n",
    "sns.move_legend(\n",
    "    plot_kl,\n",
    "    loc='upper center',\n",
    "    ncol=len(cfg_info),\n",
    "    title='',\n",
    "    bbox_to_anchor=(.455, 1.06),\n",
    "    frameon=True,\n",
    "    fancybox=True,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "b108c607-90d9-4470-b7ef-ef1157a26192",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Event Likelihood: Direct Monte-Carlo\n",
      "Data: P(E) = 0.034+-0.001\n",
      "DM: P(E) = 0.032+-0.001\n",
      "FM: P(E) = 0.034+-0.001\n",
      "FM+Reg: P(E) = 0.033+-0.001\n"
     ]
    }
   ],
   "source": [
    "infos = {\n",
    "    k: info for k, info in cfg_info.items()\n",
    "    if not info['cfg'].model.sample_event_conditioned\n",
    "}\n",
    "print('Event Likelihood: Direct Monte-Carlo')\n",
    "for (_, source), info in ((('', 'Data'), {'df_constraint': df_constraint_data}), *infos.items()):\n",
    "    is_event = info['df_constraint']['Constraint Value'] > 0\n",
    "    print(f'{source}: P(E) = {is_event.mean():.3f}+-{is_event.std()/jnp.sqrt(len(is_event)):.3f}')"
   ]
  }
 ],
 "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
