{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "99d811ee-0b10-45a2-b0b4-9eb77d03cc12",
   "metadata": {},
   "source": [
    "# ODE NHP Sequence Prediction Test\n",
    "\n",
    "Test ODE-GRU network with NHP loss on synthetic data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5d15cc90-4432-414b-be82-2b68989faad8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import torch\n",
    "import hotpp\n",
    "import seaborn as sns\n",
    "from hotpp.data import PaddedBatch\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "DEVICE = \"cuda\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "17f21a8e-d879-44c1-ac33-fce6c7d5d3d0",
   "metadata": {},
   "source": [
    "# Dataset\n",
    "\n",
    "Synthetic dataset with a predefined distribution of time delta."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a6c94e50-838b-4ccd-8c09-9a9f4711ae9a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "class DTDistribution:\n",
    "    def __init__(self, label=0):\n",
    "        if label == 0:\n",
    "            self.means = torch.tensor([1, 3]).float()\n",
    "            self.stds = torch.tensor([0.2, 1])\n",
    "            self.probs = torch.tensor([0.7, 0.3])\n",
    "        elif label == 1:\n",
    "            self.means = torch.tensor([2]).float()\n",
    "            self.stds = torch.tensor([0.5])\n",
    "            self.probs = torch.tensor([1.0])\n",
    "        else:\n",
    "            raise NotImplementedError(label)\n",
    "\n",
    "    @property\n",
    "    def entropy(self):\n",
    "        n = 10000\n",
    "        s = self.sample(10000)\n",
    "        return -self.log_pdf(s).mean()\n",
    "\n",
    "    @property\n",
    "    def expectation(self):\n",
    "        return (self.means * self.probs).sum()\n",
    "\n",
    "    def log_pdf(self, dt):\n",
    "        nc = len(self.means)\n",
    "        shape = [nc] + [1] * dt.ndim\n",
    "        means = self.means.reshape(*shape)\n",
    "        stds = self.stds.reshape(*shape)\n",
    "        probs = self.probs.reshape(*shape)\n",
    "        log_pdfs = -0.5 * (2 * math.pi * stds ** 2).log() - (means - dt) ** 2 / 2 / stds ** 2\n",
    "        return torch.logsumexp(log_pdfs + probs.log(), 0)\n",
    "\n",
    "    def sample(self, size):\n",
    "        components = torch.multinomial(self.probs, size, replacement=True)  # S.\n",
    "        sample = (torch.randn(size, 1) * self.stds + self.means).take_along_dim(components[:, None], 1).squeeze(1)\n",
    "        return sample.clip(min=0)\n",
    "\n",
    "    def plot(self, sample_size=20, ax=None):\n",
    "        if ax is None:\n",
    "            ax = plt.gca()\n",
    "        x_min = 0\n",
    "        x_max = self.means.max().item() + self.stds.max().item() * 2\n",
    "        ax.set_xlim(x_min, x_max)\n",
    "        if sample_size:\n",
    "            sample = self.sample(sample_size)\n",
    "            for x in sample:\n",
    "                ax.axvline(x, 0, 1, linewidth=0.5)\n",
    "\n",
    "        xs = torch.linspace(x_min, x_max, 1000)\n",
    "        pdfs = self.log_pdf(xs).exp()\n",
    "        # Fix filling.\n",
    "        xs[-1] = xs[-2]\n",
    "        pdfs[-1] = 0\n",
    "        ax.fill(xs, pdfs, alpha=0.5)\n",
    "\n",
    "DTDistribution().plot()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0b2e9b7d-db89-47ec-86e7-bdc5b836acfe",
   "metadata": {},
   "source": [
    "**Create batch**\n",
    "\n",
    "Each sequences is composed of two timestamps: 0 and sampled. All labels are identical."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3bb36262-6d3b-4d3e-87ad-143727d5ac24",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1000, 20])\n"
     ]
    }
   ],
   "source": [
    "batch_size = 1000\n",
    "sample_size = 10\n",
    "prefetch_factor = 10  # Sample more data to prevent time delta distortions after sorting.\n",
    "num_labels = 2\n",
    "\n",
    "time_deltas = torch.stack([DTDistribution(label).sample(batch_size * sample_size * prefetch_factor).reshape(batch_size, sample_size * prefetch_factor)\n",
    "                           for label in range(num_labels)], 1)  # (B, N, S).\n",
    "timestamps = time_deltas.cumsum(-1).flatten(1, 2)  # (B, L).\n",
    "labels = torch.cat([torch.full([batch_size, sample_size * prefetch_factor], label, dtype=torch.long)\n",
    "                    for label in range(num_labels)], 1)  # (B, L).\n",
    "timestamps, order = timestamps.sort(dim=1)\n",
    "labels = labels.take_along_dim(order, 1)\n",
    "\n",
    "# Drop tails to suppress time delta distortions after sorting.\n",
    "timestamps = timestamps[:, :sample_size * num_labels]\n",
    "labels = labels[:, :sample_size * num_labels]\n",
    "\n",
    "batch = PaddedBatch(\n",
    "    {\n",
    "        \"timestamps\": timestamps,  # (B, L).\n",
    "        \"labels\": labels  # (B, L).\n",
    "    },\n",
    "    torch.full([batch_size], sample_size * num_labels)\n",
    ")\n",
    "print(batch.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c9ca3299-b5cc-4619-bc51-cbec20485827",
   "metadata": {},
   "source": [
    "# Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d31f3965-9ebe-4a96-8eda-ef5cf26335c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "module = hotpp.modules.NextItemModule(\n",
    "    seq_encoder=hotpp.nn.RnnEncoder(\n",
    "        embeddings={\"labels\": {\"in\": num_labels, \"out\": 16}},\n",
    "        rnn_partial=lambda dim: hotpp.nn.ODEGRU(dim, 16, num_diff_layers=3),\n",
    "    ),\n",
    "    head_partial=lambda idim, odim: hotpp.nn.Head(idim, odim, hidden_dims=[16]),\n",
    "    loss=hotpp.losses.NHPLoss(num_labels, thinning_params={\"max_delta\": 5, \"max_steps\": 100}),\n",
    "    optimizer_partial=lambda p: torch.optim.Adam(p, lr=0.001)\n",
    ")\n",
    "module = module.to(DEVICE).eval()\n",
    "batch = batch.to(DEVICE)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d6c931c-fb6a-4a42-98b1-237204a66efc",
   "metadata": {},
   "source": [
    "# Train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cf01141a-998f-4ef7-b46f-d40bfa43b8fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean entropy (minimum expected loss): 0.772\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "You are trying to `self.log()` but the `self.trainer` reference is not registered on the model yet. This is most likely because the model hasn't been passed to the `Trainer`\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Step 0, Loss 1.68, Grad 0.61\n",
      "Step 200, Loss 1.03, Grad 0.09\n",
      "Step 400, Loss 0.83, Grad 0.07\n",
      "Step 600, Loss 0.79, Grad 0.05\n",
      "Step 800, Loss 0.78, Grad 0.17\n",
      "Step 1000, Loss 0.78, Grad 0.08\n",
      "Step 1200, Loss 0.77, Grad 0.14\n",
      "Step 1400, Loss 0.77, Grad 0.16\n",
      "Step 1600, Loss 0.77, Grad 0.21\n",
      "Step 1800, Loss 0.76, Grad 0.36\n"
     ]
    }
   ],
   "source": [
    "entropy = np.mean([DTDistribution(label).entropy.item() for label in range(num_labels)])\n",
    "print(f\"Mean entropy (minimum expected loss): {entropy:.3f}\")\n",
    "\n",
    "module.train()\n",
    "optimizer = module.configure_optimizers()\n",
    "for step in range(2000):\n",
    "    loss = module.training_step((batch, None), None)\n",
    "    optimizer.zero_grad()\n",
    "    loss.backward()\n",
    "    grad_norm = torch.nn.utils.clip_grad_norm_(module.parameters(), 1)\n",
    "    if step % 200 == 0:\n",
    "        print(f\"Step {step}, Loss {loss.item():.2f}, Grad {grad_norm.item():.2f}\")\n",
    "    optimizer.step()\n",
    "module.eval()\n",
    "pass"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c1a1636c-b874-437f-b1d8-d31e25bd7658",
   "metadata": {},
   "source": [
    "# Test generation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0f199cb8-81a8-471d-a43f-bad1e18f14f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([200, 1, 100])\n"
     ]
    }
   ],
   "source": [
    "sample_size = 100\n",
    "gen_times = torch.rand(sample_size * num_labels)\n",
    "gen_labels = (torch.zeros(1, sample_size, dtype=torch.long) + torch.arange(num_labels)[:, None]).flatten()\n",
    "gen_prefixes = PaddedBatch({\"timestamps\": gen_times[:, None],\n",
    "                            \"labels\": gen_labels[:, None]},\n",
    "                            torch.ones(len(gen_times), dtype=torch.long)).to(DEVICE)\n",
    "indices = PaddedBatch(torch.zeros(len(gen_prefixes), 1, dtype=torch.long),\n",
    "                      torch.ones(len(gen_prefixes), dtype=torch.long)).to(DEVICE)\n",
    "\n",
    "module._loss._thinning_params[\"max_steps\"] = 100\n",
    "module._loss._prediction = \"sample\"\n",
    "try:\n",
    "    with torch.no_grad():\n",
    "        sequences = module.generate_sequences(gen_prefixes, indices, 100)\n",
    "finally:\n",
    "    module._loss._thinning_params[\"max_steps\"] = 10000\n",
    "    module._loss._prediction = \"mean\"\n",
    "print(sequences.payload[\"timestamps\"].shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e9eb7312-101b-4b47-9dad-26060f614792",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Labels priors: tensor([0.5613, 0.4387], device='cuda:0')\n",
      "Output label probs: tensor([0.5530, 0.4469], device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "counts = batch.payload[\"labels\"].flatten().bincount()\n",
    "print(\"Labels priors:\", counts / counts.sum())\n",
    "counts = sequences.payload[\"labels\"].flatten().bincount()\n",
    "print(\"Output label probs:\", counts / counts.sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9cf072e3-1b9c-495e-941e-b07691c20614",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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qKmpwd///necf/75+OGHH5CTkwMgsBx42223Ye7cubj99tvhdDrx7bff4quvvsJ1110HALj55puxYcMGLFmyBGPGjEFDQwM+//xz/Pjjj5g0aVKH4/76669x6qmnwmAwhF2fOnUqAGDfvn3Iy8vr8PEUZUSiCLR48WKxo7fvggULxGHDhoW+PnbsmAhATE9PF5ubm0PXly9fLgIQCwoKRI/HE7p+7bXXimq1WnQ6naIoiqLFYhGTkpLEm266Kex1qqurRaPR2Ob6ie644w4RgPjVV1+FrtXW1opGo1EEIB47dqzbr7Ny5co2v3+9Xi8uWLCgzevb7fY213bs2CECENevX3/SsW/cuFEEIP71r38NXfN6veK5554rAhBfeumlDsf0xBNPiADEurq6Dp9/165dbZ5Hcv7554sAxLVr17b7vfPPPz/09SeffCICEHNzc0Wz2Ry6/q9//UsEID755JOha8OGDWv353Tic55sbCe+x6Sf04MPPhh2v7lz54qCIIiHDx8OXQMgqtXqsGvffPONCEB86qmn2rzWiQCIixcvDrsmvcc+++yz0DWLxSIOHz5czM/PF30+nyiKLT+nU045pd33xYk+/vhjEYB42223tfme3+8P/frEn6nT6Qy9puTYsWOiRqMR77///tC1K6+8Uhw7duxJx2A0Gtv8frti7Nix4syZM9tc379/f4fvK4peXMaimHH11VfDaDSGvi4sLAQQqAdqXWtSWFgIt9uNiooKAIGlmObmZlx77bWor68P3ZRKJQoLC/HJJ5+c9HU/+OADnHXWWaF/UQJAeno6rr/++rD79fZ1OtJ6RsPj8aChoQEjR45EUlJSp0sBH3zwAVQqFX7729+GrimVStx6662dvq5UV/Luu+/2uJhXo9Fg0aJFXb7//PnzkZiYGPp67ty5yM7OxgcffNCj1++qDz74AEqlErfddlvY9d///vcQRRH/+c9/wq4XFRWFZt4AYPz48TAYDDh69GiPX3/q1KlhRbcJCQn4zW9+g5KSEvzwww9h91+wYEGXZrr+/e9/QxAErFy5ss33TtZmQKPRhGqAfD4fGhoaQsuYrd9zSUlJOH78OHbt2tXhcyUlJeGrr75CZWVlp+NtzeFwQKPRtLmu1WpD36fYwbBDMWPo0KFhX0vB58SpbOl6U1MTAODQoUMAgJkzZyI9PT3stnnzZtTW1p70dUtLSzFq1Kg210ePHh32dW9fpyMOhwMrVqwI1ZKkpaUhPT0dzc3NMJlMnY49OzsbCQkJJx17e+bNm4fp06fjxhtvRGZmJq655hr861//6lbwyc3N7VYx8ok/Z0EQMHLkyB71MuqO0tJS5OTkhAUtILAcJn2/tRPfiwCQnJwces/15PXb+zPp6PWHDx/epec9cuQIcnJykJKS0q3x+P1+PPHEExg1alTYe+7bb78Ne8/deeedSEhIwNSpUzFq1CgsXrw4tMwp+etf/4rvv/8eeXl5mDp1Ku69994uhUKdTgeXy9XmutPpDH2fYgdrdihmKJXKbl0Xg4Wl0ofzK6+8gqysrDb366sdSP31Orfeeiteeukl3HHHHZg2bRqMRiMEQcA111zTr9undTodtm/fjk8++QTvv/8+Nm3ahDfffBMzZ87E5s2bO/y5n/gcfa2jGQmfz9elMfWFzt5z/a2/P+gfeugh3HPPPfif//kfPPDAA0hJSYFCocAdd9wR9p47/fTT8dNPP+G9997Dpk2b8O9//xvPPPMMVqxYgfvuuw8A8Mtf/hLnnnsu3nnnHWzevBmPPPII/vKXv+Dtt9/G7NmzOxxDdnZ2aHa2taqqKgAI1Q1RbGDYIeqEtNyQkZGBoqKibj9+2LBhoVmb1n766ac+fZ2OPsQ3bNiABQsW4LHHHgtdczqd7e6oOtGwYcOwdetWWK3WsNmdE8feEYVCgQsvvBAXXnghHn/8cTz00EP405/+hE8++QRFRUV93nH5xJ+zKIo4fPgwxo8fH7qWnJzc7u+9tLQUp5xySujr7oxt2LBh+Oijj2CxWMJmdw4cOBD6fn8aNmxYu38mvX39ESNG4MMPP0RjY2O3Znc2bNiAGTNm4IUXXgi73tzcjLS0tLBrer0e8+bNw7x58+B2u/Hzn/8cf/7zn7F8+fLQklN2djZuueUW3HLLLaitrcWkSZPw5z//+aRhZ8KECfjkk09gNpvDipS/+uqr0PcpdnAZi6gTs2bNgsFgwEMPPQSPx9Pm+3V1dSd9/KWXXoovv/wSO3fuDHvMq6++2qevo9fr2/0QVyqVbWYMnnrqKfh8vpM+nzR2r9eLZ599NnTN5/Phqaee6vSx7W3flz5gpOUFvV4PAF0KXl2xfv16WCyW0NcbNmxAVVVV2IfiiBEj8OWXX8Ltdoeuvffee222IndnbJdeeil8Ph+efvrpsOtPPPEEBEE46YdyX7j00kuxc+dO7NixI3TNZrPhueeeQ35+PsaMGdOj5/3FL34BURRDsyytnWwWqr333FtvvdVmpqWhoSHsa7VajTFjxkAURXg8Hvh8vjZLrRkZGcjJyWl3iaq1uXPnwufz4bnnngtdc7lceOmll1BYWMidWDGGMztEnTAYDHj22Wdxww03YNKkSbjmmmuQnp6OsrIyvP/++5g+fXqbD7nW/vjHP4ba+t9+++2hrefDhg3Dt99+22evM3nyZHz00Ud4/PHHkZOTg+HDh6OwsBCXX345XnnlFRiNRowZMwY7duzARx991OEW59bmzJmD6dOnY9myZSgpKcGYMWPw9ttvd1rrAwD3338/tm/fjssuuwzDhg1DbW0tnnnmGQwZMiRUSDtixAgkJSVh7dq1SExMhF6vR2FhYZdrSk6UkpKCc845B4sWLUJNTQ1Wr16NkSNH4qabbgrd58Ybb8SGDRtwySWX4Je//CWOHDmCf/7zn2EFw90d25w5czBjxgz86U9/QklJCQoKCrB582a8++67uOOOO9o8d19btmwZXn/9dcyePRu33XYbUlJS8PLLL+PYsWP497//3eOGgTNmzMANN9yAv/3tbzh06BAuueQS+P1+fPbZZ5gxYwaWLFnS7uMuv/xy3H///Vi0aBHOPvtsfPfdd3j11VfDZs4A4OKLL0ZWVhamT5+OzMxM/Pjjj3j66adx2WWXITExEc3NzRgyZAjmzp2LgoICJCQk4KOPPsKuXbvCZirbU1hYiKuvvhrLly9HbW0tRo4ciZdffhklJSVtZpwoBsi2D4yoF3qy9fyRRx4Ju5+0Dfett94Ku/7SSy+JAMRdu3a1uf+sWbNEo9EoarVaccSIEeLChQvF3bt3dzreb7/9Vjz//PNFrVYr5ubmig888ID4wgsvhG09787rtLf1/MCBA+J5550n6nQ6EUBoK3BTU5O4aNEiMS0tTUxISBBnzZolHjhwoMMt2CdqaGgQb7jhBtFgMIhGo1G84YYbxK+//rrTredbt24Vr7zySjEnJ0dUq9ViTk6OeO2114oHDx4Me/53331XHDNmjKhSqcKe8/zzz+9wW3JHW89ff/11cfny5WJGRoao0+nEyy67TCwtLW3z+Mcee0zMzc0VNRqNOH36dHH37t1tnvNkYzvxPSaKga3ev/vd78ScnBwxLi5OHDVqlPjII4+EbdEWxfa3jotix1viT9TR448cOSLOnTtXTEpKErVarTh16lTxvffeC7tPR+/5k/F6veIjjzwinnbaaaJarRbT09PF2bNni3v27Olw7E6nU/z9738vZmdnizqdTpw+fbq4Y8eONj/jv//97+J5550npqamihqNRhwxYoT4hz/8QTSZTKIoiqLL5RL/8Ic/iAUFBWJiYqKo1+vFgoIC8ZlnnunS2B0Oh7h06VIxKytL1Gg04plnnilu2rSpy793ih6CKA5QRRwRERGRDFizQ0RERFGNYYeIiIiiGsMOERERRTWGHSIiIopqDDtEREQU1Rh2iIiIKKrFXFNBv9+PyspKJCYm9nmreiIiIuofoijCYrEgJyen240yYy7sVFZWsk04ERFRhCovL8eQIUO69ZiYCzvSIX3l5eVhh8MRERHR4GU2m5GXlxd22G5XxVzYkZauDAYDww4REVGE6UkJCguUiYiIKKox7BAREVFUY9ghIiKiqMawQ0RERFGNYYeIiIiiGsMOERERRTWGHSIiIopqDDtEREQU1Rh2iIiIKKox7BAREVFUY9ghIiKiqMawQ0RERFGNYYeIiIiiGsMOERERRTVZw8727dsxZ84c5OTkQBAEbNy4scuP/e9//wuVSoUJEyb02/iof1WZHHjv20ocqbPKPRQiIopisoYdm82GgoICrFmzpluPa25uxvz583HhhRf208iov5nsHry9twKHaqx475sqVDY75B4SERFFKZWcLz579mzMnj2724+7+eabcd1110GpVHY6G+RyueByuUJfm83mbr8e9b3PDtfB7fUDAPyiiE9+qsV1U4dCEASZR0ZERNEm4mp2XnrpJRw9ehQrV67s0v1XrVoFo9EYuuXl5fXzCKkzzXY3DteGL13Vml0ob+TsDhER9b2ICjuHDh3CsmXL8M9//hMqVdcmpZYvXw6TyRS6lZeX9/MoqTPfV5ghim2vf1dhGvjBEBFR1JN1Gas7fD4frrvuOtx333049dRTu/w4jUYDjUbTjyOj7hBFET/VWNr93tE6K1xeHzQq5QCPioiIolnEhB2LxYLdu3fj66+/xpIlSwAAfr8foihCpVJh8+bNmDlzpsyjpM7UWVwwOzztfs/rF1HaYMepmYkDPCoiIopmERN2DAYDvvvuu7BrzzzzDD7++GNs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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAGzCAYAAADDgXghAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAABzvklEQVR4nO3deXiU1dkG8HuWzGSfJGQPIWHfCZsgIAIaRbCKa9G2gtSldana1H6CC1RtRasiVqm0VsRdKipWRRYjLmjYEpYQAoHs20z2WTP7+f4YGAxZSEKSN8ncv+uaS/POeWeeeZlMnjnnOefIhBACRERERD5ILnUARERERFJhIkREREQ+i4kQERER+SwmQkREROSzmAgRERGRz2IiRERERD6LiRARERH5LCZCRERE5LOYCBEREZHPYiJE/c7tt9+O5ORkqcM4r40bN0Imk6GoqKjD5/7lL3+BTCbr+qDaqaioCDKZDBs3bpQkprlz52Lu3Lnen7/99lvIZDJs3ry5R55fyveYTqfDTTfdhAEDBkAmk2Ht2rWSxPFzycnJuP3226UOg6hTmAhRnyCTydp1+/bbb6UOVTLPPPMMtmzZInUYHVJRUYG//OUvOHTokNShNNNbY/vjH/+I7du3Y8WKFXjnnXdw1VVXSR1Sr2QymbBq1SpcddVViIiIaJa4E52hlDoAovZ45513mvz89ttvY+fOnc2Ojx49Gq+//jrcbndPhtcrPPPMM7jppptw3XXXSfL8jz/+OJYvX96hcyoqKvDkk08iOTkZEydObPd5O3bs6GB0HddWbFK+x7755hssWrQIDz/8sCTP31fU1NTgqaeewqBBg5CSkuLTX5KobUyEqE/4zW9+0+TnPXv2YOfOnc2Ok3SUSiWUyu79SLFYLAgMDIRKperW5zkfPz8/yZ67qqoKYWFhXfZ4VqsVKpUKcnn/GiCIi4tDZWUlYmNjceDAAVx00UVSh0S9VP965xOhef3GmXqWF154AevWrcOQIUMQGBiIK6+8EqWlpRBC4Omnn8bAgQMREBCARYsWoa6urtnjfvXVV5g9ezaCgoIQEhKCq6++Gjk5Oe2KKScnB5dddhkCAgIwcOBA/PWvf221R6EzzyOTyWA2m/HWW295hwnP1GwUFxfj3nvvxciRIxEQEIABAwbg5ptvbndtUkNDA26//XZoNBqEhYVh6dKlaGhoaNaupRqhnTt34pJLLkFYWBiCg4MxcuRIPProowA8dT1n/jgtW7bMG/eZ4Yu5c+di3LhxyMzMxKWXXorAwEDvuefWCJ3hcrnw6KOPIjY2FkFBQbj22mtRWlrapE1r9Sw/f8zzxdZSjZDZbMaf/vQnJCYmQq1WY+TIkXjhhRcghGjSTiaT4f7778eWLVswbtw4qNVqjB07Ftu2bWsW08+dqSkTQmDdunXemM4oKCjAzTffjIiICAQGBuLiiy/Gl19+2eQxztRSffjhh3j88ceRkJCAwMBAGAyGVp/X7Xbj5Zdfxvjx4+Hv74+oqChcddVVOHDgQKvn1NXV4eGHH8b48eMRHByM0NBQLFiwAIcPH27W9pVXXsHYsWMRGBiI8PBwTJ06Fe+//773fqPRiIceegjJyclQq9WIjo7GFVdcgaysrDavl1qtRmxsbJttiAD2CJEPee+992C32/GHP/wBdXV1+Pvf/45f/vKXuOyyy/Dtt9/ikUcewalTp/DKK6/g4YcfxoYNG7znvvPOO1i6dCnmz5+P5557DhaLBa+99houueQSHDx4sM3CWa1Wi3nz5sHpdGL58uUICgrCv//9bwQEBDRr29nneeedd3DnnXdi2rRpuPvuuwEAQ4cOBQDs378fP/30E2655RYMHDgQRUVFeO211zB37lwcO3YMgYGBrcYuhMCiRYuwe/du/P73v8fo0aPx6aefYunSpee93jk5OfjFL36BCRMm4KmnnoJarcapU6fw448/AvAMYz711FNYuXIl7r77bsyePRsAMHPmTO9j1NbWYsGCBbjlllvwm9/8BjExMW0+59/+9jfIZDI88sgjqKqqwtq1a5GamopDhw61eL1b057Yfk4IgWuvvRa7du3CHXfcgYkTJ2L79u3485//jPLycrz00ktN2u/evRuffPIJ7r33XoSEhOAf//gHbrzxRpSUlGDAgAEtPsell16Kd955B7fddhuuuOIKLFmyxHufTqfDzJkzYbFY8MADD2DAgAF46623cO2112Lz5s24/vrrmzzW008/DZVKhYcffhg2m63NHrY77rgDGzduxIIFC3DnnXfC6XTihx9+wJ49ezB16tQWzykoKMCWLVtw8803Y/DgwdDpdPjXv/6FOXPm4NixY4iPjwfgGWJ84IEHcNNNN+HBBx+E1WrFkSNHsHfvXvzqV78CAPz+97/H5s2bcf/992PMmDGora3F7t27kZubi8mTJ7caN1G7CaI+6L777hOtvX2XLl0qkpKSvD8XFhYKACIqKko0NDR4j69YsUIAECkpKcLhcHiP33rrrUKlUgmr1SqEEMJoNIqwsDBx1113NXkerVYrNBpNs+PneuihhwQAsXfvXu+xqqoqodFoBABRWFjY4edZtWpVs9cfFBQkli5d2uz5LRZLs2MZGRkCgHj77bfbjH3Lli0CgPj73//uPeZ0OsXs2bMFAPHmm2+2GtNLL70kAIjq6upWH3///v3NHueMOXPmCABi/fr1Ld43Z84c78+7du0SAERCQoIwGAze4//9738FAPHyyy97jyUlJbV4nc59zLZiO/c9duY6/fWvf23S7qabbhIymUycOnXKewyAUKlUTY4dPnxYABCvvPJKs+c6FwBx3333NTl25j32ww8/eI8ZjUYxePBgkZycLFwulxDi7HUaMmRIi++Lc33zzTcCgHjggQea3ed2u73/f+41tVqt3uc8o7CwUKjVavHUU095jy1atEiMHTu2zRg0Gk2z19tRbf1bEnFojHzGzTffDI1G4/15+vTpADz1Rz+vbZk+fTrsdjvKy8sBeIZ3GhoacOutt6KmpsZ7UygUmD59Onbt2tXm827duhUXX3wxpk2b5j0WFRWFX//6103aXejztObnPSEOhwO1tbUYNmwYwsLCzju8sHXrViiVStxzzz3eYwqFAn/4wx/O+7xn6lg+++yzThcWq9VqLFu2rN3tlyxZgpCQEO/PN910E+Li4rB169ZOPX97bd26FQqFAg888ECT43/6058ghMBXX33V5Hhqaqq3xw4AJkyYgNDQUBQUFHT6+adNm4ZLLrnEeyw4OBh33303ioqKcOzYsSbtly5d2q4eso8//hgymQyrVq1qdl9bSyWo1WpvzZHL5UJtba13aPTn77mwsDCUlZVh//79rT5WWFgY9u7di4qKivPGS9QZTITIZwwaNKjJz2eSosTExBaP19fXAwBOnjwJALjssssQFRXV5LZjxw5UVVW1+bzFxcUYPnx4s+MjR45s8vOFPk9rGhsbsXLlSm/tSmRkJKKiotDQ0AC9Xn/e2OPi4hAcHNxm7C1ZvHgxZs2ahTvvvBMxMTG45ZZb8N///rdDSVFCQkKHCqPPvc4ymQzDhg3r1FpNHVFcXIz4+PgmSRjgGWI7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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "timestamps = sequences.payload[\"timestamps\"].squeeze().cpu()\n",
    "labels = sequences.payload[\"labels\"].squeeze().cpu()\n",
    "for label in range(num_labels):\n",
    "    mask = labels == label\n",
    "    deltas = torch.cat([\n",
    "        ts[m][1:] - ts[m][:-1]\n",
    "        for ts, m in zip(timestamps, mask)\n",
    "    ])\n",
    "    DTDistribution(label).plot(None)\n",
    "    sns.kdeplot(deltas, label=label, bw_adjust=.5)\n",
    "    plt.title(f\"Time delta distribution for class {label}\")\n",
    "    plt.show()"
   ]
  }
 ],
 "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
