{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4ce6f328",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "import sys\n",
    "sys.path.append(\"../src\")\n",
    "import model.sdes as sdes\n",
    "import model.generate as generate\n",
    "import model.table_dnn as table_dnn\n",
    "import model.util as model_util\n",
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "df22d86f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define device\n",
    "if torch.cuda.is_available():\n",
    "    DEVICE = \"cuda\"\n",
    "else:\n",
    "    DEVICE = \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dfe528ba",
   "metadata": {},
   "source": [
    "### Define the classes and create the data loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e395da27",
   "metadata": {},
   "outputs": [],
   "source": [
    "letters = list(\"ABCDEFGHIJKLMNOPQRSTUVWXYZ\")\n",
    "class_to_letter = dict(enumerate(letters))\n",
    "letter_to_class = {v : k for k, v in class_to_letter.items()}\n",
    "\n",
    "classes = [letter_to_class[l] for l in (\"A\", \"V\", \"Y\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "10b7dc3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "class LetterDataset(torch.utils.data.Dataset):\n",
    "    def __init__(self):\n",
    "        data_path = \"/data/anon/branched_diffusion/data/letter_recognition/letter-recognition.data\"\n",
    "        \n",
    "        data = []\n",
    "        targets = []\n",
    "        with open(data_path, \"r\") as f:\n",
    "            for line in f:\n",
    "                tokens = line.strip().split(\",\")\n",
    "                targets.append(tokens[0])\n",
    "                data.append(np.array(list(map(int, tokens[1:]))))\n",
    "        self.data = np.stack(data)\n",
    "        self.targets = np.array([letter_to_class[l] for l in targets])\n",
    "        \n",
    "        # Center/normalize the data\n",
    "        self.data = (self.data - np.mean(self.data, axis=0, keepdims=True)) / \\\n",
    "            np.std(self.data, axis=0, keepdims=True)\n",
    "        \n",
    "    def __getitem__(self, index):\n",
    "        return torch.tensor(self.data[index]).float(), self.targets[index]\n",
    "        \n",
    "    def __len__(self):\n",
    "        return len(self.targets)\n",
    "    \n",
    "dataset = LetterDataset()\n",
    "\n",
    "# Limit classes\n",
    "inds = np.isin(dataset.targets, classes)\n",
    "dataset.data = dataset.data[inds]\n",
    "dataset.targets = dataset.targets[inds]\n",
    "\n",
    "data_loader = torch.utils.data.DataLoader(dataset, batch_size=128, shuffle=True, num_workers=2)\n",
    "input_shape = next(iter(data_loader))[0].shape[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a0612f24",
   "metadata": {},
   "outputs": [],
   "source": [
    "def class_to_class_index_tensor(c):\n",
    "    \"\"\"\n",
    "    Given a tensor of classes, return the corresponding class indices\n",
    "    as a tensor.\n",
    "    \"\"\"\n",
    "    return torch.argmax(\n",
    "        (c[:, None] == torch.tensor(classes, device=c.device)).int(), dim=1\n",
    "    ).to(DEVICE)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bdcebba8",
   "metadata": {},
   "source": [
    "### Create the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "7bfce9c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create the SDE and model\n",
    "sde = sdes.VariancePreservingSDE(0.1, 1, input_shape)\n",
    "\n",
    "t_limit = 1\n",
    "model = table_dnn.LabelGuidedTabularNet(\n",
    "    len(classes), input_shape[0], t_limit=t_limit\n",
    ").to(DEVICE)\n",
    "\n",
    "os.environ[\"MODEL_DIR\"] = \"/data/anon/branched_diffusion/models/trained_models/letters_continuous_AVY_labelguided\"\n",
    "\n",
    "import model.train_continuous_model as train_continuous_model  # Import this AFTER setting environment"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c07baf0",
   "metadata": {},
   "source": [
    "### Show the forward-diffusion process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1efc4143",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1440x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Show the transformation of the distribution of data to the prior distribution\n",
    "x0, _ = next(iter(data_loader))\n",
    "x0 = x0.cpu().numpy()\n",
    "x0 = torch.tensor(x0).to(DEVICE)\n",
    "\n",
    "time_steps = 30\n",
    "\n",
    "all_t = np.linspace(0, t_limit, time_steps)\n",
    "all_xt = np.empty((len(all_t),) + x0.shape)\n",
    "for t_i, t in enumerate(all_t):\n",
    "    xt, _ = sde.forward(x0, torch.ones(len(x0)).to(DEVICE) * t)\n",
    "    all_xt[t_i] = xt.cpu().numpy()\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(20, 8))\n",
    "cmap = plt.get_cmap(\"magma\")\n",
    "for t_i in range(len(all_t)):\n",
    "    ax.hist(np.ravel(all_xt[t_i]), bins=60, histtype=\"step\", color=cmap(t_i / len(all_t)), alpha=0.5, density=True)\n",
    "prior = sde.sample_prior(len(x0), torch.ones(len(x0)).to(DEVICE) * t).cpu().numpy()\n",
    "ax.hist(np.ravel(prior), bins=60, histtype=\"step\", color=\"blue\", linewidth=2, density=True, label=\"Sampled prior\")\n",
    "ax.set_xlabel(\"x\")\n",
    "ax.set_ylabel(\"p(x)\")\n",
    "ax.set_title(\"Evolution of p(x) over forward SDE\")\n",
    "ax.set_ylim((0, 3))\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f19ff6b",
   "metadata": {},
   "source": [
    "### Train the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "77f13f9c",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING - root - Added new config entry: \"class_to_class_index\"\n",
      "WARNING - root - Added new config entry: \"data_loader\"\n",
      "WARNING - root - Added new config entry: \"loss_weighting_type\"\n",
      "WARNING - root - Added new config entry: \"model\"\n",
      "WARNING - root - Added new config entry: \"sde\"\n",
      "WARNING - root - Added new config entry: \"t_limit\"\n",
      "INFO - train - Running command 'train_label_guided_model'\n",
      "INFO - train - Started run with ID \"1\"\n",
      "Loss: 14.46: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 25.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 average Loss: 15.46\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 11.57: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 average Loss: 13.19\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 11.13: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 average Loss: 11.76\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.67: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 average Loss: 10.94\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 10.21: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 average Loss: 10.49\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.85: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 average Loss: 10.04\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.33: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 average Loss: 9.67\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.45: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.82it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 average Loss: 9.68\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.74: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 average Loss: 9.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.25: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 average Loss: 9.18\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.38: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 average Loss: 9.21\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.90: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 42.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 average Loss: 9.06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.59: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 average Loss: 8.88\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.86: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 average Loss: 8.81\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.02: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 42.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 average Loss: 8.61\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.31: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 average Loss: 8.67\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 10.27: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 42.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 average Loss: 8.71\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.17: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 average Loss: 8.51\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.91: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 average Loss: 8.54\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.91: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 average Loss: 8.53\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.37: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 43.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 average Loss: 8.41\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.78: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 52.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 average Loss: 8.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.28: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 41.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 average Loss: 8.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.44: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 average Loss: 8.19\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.36: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 average Loss: 8.27\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.51: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 40.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 average Loss: 8.14\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.22: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 average Loss: 8.18\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.74: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 average Loss: 8.08\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.86: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 average Loss: 8.14\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.62: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 average Loss: 7.98\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.54: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 average Loss: 7.99\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.93: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 average Loss: 7.96\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.45: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 average Loss: 7.97\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.43: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 average Loss: 8.12\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.72: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 average Loss: 7.87\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.32: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.92it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 average Loss: 7.76\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.47: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 44.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 average Loss: 7.82\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.23: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 average Loss: 7.96\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.22: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 average Loss: 7.77\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.16: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 average Loss: 7.80\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.14: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 average Loss: 7.76\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.36: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.45it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 average Loss: 7.96\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.87: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 average Loss: 7.85\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.21: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 average Loss: 7.62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.77: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 average Loss: 7.72\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.45: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 average Loss: 7.77\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.10: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 average Loss: 7.55\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.44: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.43it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 average Loss: 7.79\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.81: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 average Loss: 7.78\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.59: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 average Loss: 7.62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.28: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 average Loss: 7.75\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.43: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 average Loss: 7.66\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 5.97: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 average Loss: 7.47\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.31: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 average Loss: 7.48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.57: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 42.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 average Loss: 7.75\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.08: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 average Loss: 7.61\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.02: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 39.15it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 average Loss: 7.53\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.22: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 average Loss: 7.39\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.64: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.94it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 average Loss: 7.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.19: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.21it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 average Loss: 7.59\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.57: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 average Loss: 7.52\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.34: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 average Loss: 7.64\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.13: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 average Loss: 7.62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.31: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 64 average Loss: 7.50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.47: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 65 average Loss: 7.59\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.36: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 38.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 66 average Loss: 7.55\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.58: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 67 average Loss: 7.64\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.81: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 68 average Loss: 7.39\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.22: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 69 average Loss: 7.52\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.81: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 70 average Loss: 7.47\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.48: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.01it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 average Loss: 7.43\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.41: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.28it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 average Loss: 7.49\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.29: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 average Loss: 7.56\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.35: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 44.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 average Loss: 7.37\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.01: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 average Loss: 7.29\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.28: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 average Loss: 7.60\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.98: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 27.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 average Loss: 7.21\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.61: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 average Loss: 7.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.43: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 average Loss: 7.33\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.10: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 average Loss: 7.28\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.06: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 45.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 average Loss: 7.27\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.97: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 average Loss: 7.13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.89: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 average Loss: 7.28\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.01: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 42.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 84 average Loss: 7.43\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.31: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 85 average Loss: 7.34\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.07: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 86 average Loss: 7.39\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 8.12: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 87 average Loss: 7.39\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.97: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 43.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 88 average Loss: 7.16\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.12: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 48.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 89 average Loss: 7.24\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.77: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 40.26it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 average Loss: 7.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.36: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 49.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 average Loss: 7.35\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.19: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 average Loss: 7.22\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.64: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 38.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 average Loss: 7.27\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.05: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 40.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 average Loss: 7.13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 9.20: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 50.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 average Loss: 7.36\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.38: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 41.54it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 average Loss: 7.15\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.43: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 41.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 average Loss: 7.19\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 6.73: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 39.24it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 average Loss: 7.16\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.82: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 46.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 average Loss: 7.20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 7.12: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████| 19/19 [00:00<00:00, 47.68it/s]\n",
      "INFO - train - Completed after 0:00:43\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 average Loss: 7.31\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<sacred.run.Run at 0x2aab5befb2b0>"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_continuous_model.train_ex.run(\n",
    "    \"train_label_guided_model\",\n",
    "    config_updates={\n",
    "        \"model\": model,\n",
    "        \"sde\": sde,\n",
    "        \"data_loader\": data_loader,\n",
    "        \"class_to_class_index\": class_to_class_index_tensor,\n",
    "        \"num_epochs\": 100,\n",
    "        \"learning_rate\": 0.001,\n",
    "        \"t_limit\": t_limit,\n",
    "        \"loss_weighting_type\": \"empirical_norm\"\n",
    "    }\n",
    ")"
   ]
  }
 ],
 "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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
