{
 "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 feature.scrna_dataset as scrna_dataset\n",
    "import model.discrete_diffusers as discrete_diffusers\n",
    "import model.generate as generate\n",
    "import model.scrna_ae as scrna_ae\n",
    "import model.util as model_util\n",
    "import torch\n",
    "import numpy as np\n",
    "import scipy.stats\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 branches and create the data loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e395da27",
   "metadata": {},
   "outputs": [],
   "source": [
    "classes = [0, 2, 3, 4, 5, 6, 8, 9, 10, 12, 14, 15, 16, 18]\n",
    "# branch_defs = [((0, 2, 3, 4, 5, 6, 8, 9, 10, 12, 14, 15, 16, 18), 0.40540540540540543, 1), ((0, 2, 3, 4, 5, 6, 8, 9, 10, 12, 14, 15, 16), 0.3733733733733734, 0.40540540540540543), ((0, 2, 3, 4, 5, 6, 8, 9, 10, 14, 15, 16), 0.3663663663663664, 0.3733733733733734), ((0, 2, 3, 4, 5, 6, 8, 10, 14, 15), 0.34734734734734735, 0.3663663663663664), ((0, 2, 3, 4, 5, 6, 8, 10, 14), 0.33733733733733734, 0.34734734734734735), ((0, 2, 3, 4, 5, 6, 8, 10), 0.3313313313313313, 0.33733733733733734), ((9, 16), 0.3033033033033033, 0.3663663663663664), ((0, 2, 3, 4, 5, 8, 10), 0.2962962962962963, 0.3313313313313313), ((0, 2, 4), 0.26226226226226224, 0.2962962962962963), ((2, 4), 0.20520520520520522, 0.26226226226226224), ((3, 5, 8, 10), 0.15615615615615616, 0.2962962962962963), ((3, 5, 8), 0.14114114114114115, 0.15615615615615616), ((3, 8), 0.0, 0.14114114114114115), ((18,), 0, 0.40540540540540543), ((12,), 0, 0.3733733733733734), ((15,), 0, 0.34734734734734735), ((14,), 0, 0.33733733733733734), ((6,), 0, 0.3313313313313313), ((16,), 0, 0.3033033033033033), ((9,), 0, 0.3033033033033033), ((0,), 0, 0.26226226226226224), ((2,), 0, 0.20520520520520522), ((4,), 0, 0.20520520520520522), ((10,), 0, 0.15615615615615616), ((5,), 0, 0.14114114114114115), ((8,), 0, 0.0), ((3,), 0, 0.0)]\n",
    "branch_defs = [((0, 2, 3, 4, 5, 6, 8, 9, 10, 12, 14, 15, 16, 18), 0, 1)]\n",
    "\n",
    "classes = [0]\n",
    "branch_defs = [((0,), 0, 1000)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "951177e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = scrna_dataset.SingleCellDataset(\n",
    "    \"/data/anon/branched_diffusion/data/scrna/covid_flu/processed/covid_flu_processed_1000_uncentered.h5\"\n",
    ")\n",
    "\n",
    "# Limit classes\n",
    "inds = np.isin(dataset.cell_cluster, classes)\n",
    "dataset.data = dataset.data[inds]\n",
    "dataset.cell_cluster = dataset.cell_cluster[inds]\n",
    "\n",
    "data_loader = torch.utils.data.DataLoader(dataset, batch_size=128, shuffle=True, num_workers=0)\n",
    "input_shape = next(iter(data_loader))[0].shape[1:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5b6d3f84",
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO: this is currently rather inefficient; a decision-tree-style structure\n",
    "# would be better\n",
    "\n",
    "def class_time_to_branch(c, t):\n",
    "    \"\"\"\n",
    "    Given a class and a time (both scalars), return the\n",
    "    corresponding branch index.\n",
    "    \"\"\"\n",
    "    for i, branch_def in enumerate(branch_defs):\n",
    "        if c in branch_def[0] and t >= branch_def[1] and t <= branch_def[2]:\n",
    "            return i\n",
    "    raise ValueError(\"Undefined class and time\")\n",
    "        \n",
    "def class_time_to_branch_tensor(c, t):\n",
    "    \"\"\"\n",
    "    Given tensors of classes and a times, return the\n",
    "    corresponding branch indices as a tensor.\n",
    "    \"\"\"\n",
    "    return torch.tensor([\n",
    "        class_time_to_branch(c_i, t_i) for c_i, t_i in zip(c, t)\n",
    "    ], device=DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ab1a36e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create the diffuser and model\n",
    "diffuser = discrete_diffusers.GaussianDiffuser(1e-4, 1e-5, input_shape)\n",
    "\n",
    "t_limit = 1000\n",
    "\n",
    "model = scrna_ae.MultitaskResNet(\n",
    "    len(branch_defs), input_shape[0], t_limit=t_limit, hidden_dim=16384\n",
    ").to(DEVICE)\n",
    "\n",
    "os.environ[\"MODEL_DIR\"] = \"/data/anon/branched_diffusion/models/trained_models/misc\"\n",
    "import model.train_discrete_model as train_discrete_model  # Import this AFTER setting environment"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3c07baf0",
   "metadata": {},
   "source": [
    "### Show the forward-diffusion process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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, _ = diffuser.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 = diffuser.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 diffusion process\")\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": 9,
   "id": "62323157",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING - root - Added new config entry: \"class_time_to_branch_index\"\n",
      "WARNING - root - Added new config entry: \"data_loader\"\n",
      "WARNING - root - Added new config entry: \"diffuser\"\n",
      "WARNING - root - Added new config entry: \"model\"\n",
      "WARNING - root - Added new config entry: \"t_limit\"\n",
      "INFO - train - Running command 'train_branched_model'\n",
      "INFO - train - Started run with ID \"3\"\n",
      "Loss: 1053.27: 100%|██████████████████████████████████████████| 61/61 [00:11<00:00,  5.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 average Loss: 12083.49\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 688.85: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 average Loss: 820.99\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 549.87: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 average Loss: 618.95\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 457.46: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 4 average Loss: 508.00\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 386.41: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 5 average Loss: 458.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 373.90: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 6 average Loss: 407.85\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 353.80: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 7 average Loss: 389.45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 333.98: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 8 average Loss: 359.53\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 395.24: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9 average Loss: 350.52\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 316.71: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 10 average Loss: 330.06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 333.25: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 11 average Loss: 310.27\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 290.53: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 12 average Loss: 299.62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 900.98: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 13 average Loss: 299.16\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 276.94: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 14 average Loss: 289.19\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 238.92: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 15 average Loss: 272.75\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 274.49: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 16 average Loss: 267.83\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 266.81: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 17 average Loss: 260.67\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 290.98: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 18 average Loss: 260.93\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 238.52: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 19 average Loss: 251.28\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 220.97: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 20 average Loss: 246.29\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 214.42: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 21 average Loss: 240.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 245.19: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 22 average Loss: 231.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 249.81: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 23 average Loss: 236.60\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 229.30: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 24 average Loss: 228.13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 204.12: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 25 average Loss: 229.85\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 204.85: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 26 average Loss: 221.52\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 190.23: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 27 average Loss: 222.48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 236.35: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 28 average Loss: 216.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 230.78: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 29 average Loss: 217.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 209.42: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 30 average Loss: 213.02\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 232.95: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 31 average Loss: 209.50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 214.97: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 32 average Loss: 210.23\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 210.43: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 33 average Loss: 208.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 205.60: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 34 average Loss: 209.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 210.52: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 35 average Loss: 207.94\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 195.57: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 36 average Loss: 203.44\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 231.02: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 37 average Loss: 203.20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 205.05: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 38 average Loss: 210.05\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 213.19: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 39 average Loss: 202.39\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 243.81: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 40 average Loss: 198.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 160.89: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 41 average Loss: 194.02\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 194.22: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 42 average Loss: 197.19\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 190.38: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 43 average Loss: 194.98\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 178.38: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.76it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 44 average Loss: 204.34\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 218.25: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 45 average Loss: 195.37\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 190.54: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46 average Loss: 191.17\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 249.81: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 47 average Loss: 189.86\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 230.73: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 48 average Loss: 186.95\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 208.98: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 49 average Loss: 191.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 207.30: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 50 average Loss: 187.81\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 188.17: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 51 average Loss: 188.00\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 196.20: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52 average Loss: 187.71\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 176.45: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53 average Loss: 181.66\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 195.35: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54 average Loss: 183.10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 159.92: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55 average Loss: 183.00\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 205.42: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56 average Loss: 179.65\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 203.32: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57 average Loss: 177.50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 185.83: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 58 average Loss: 180.04\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 217.03: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 59 average Loss: 177.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 166.57: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 60 average Loss: 174.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 177.37: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 61 average Loss: 175.57\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 155.06: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 62 average Loss: 177.49\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 182.83: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 63 average Loss: 174.97\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 171.97: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 71 average Loss: 170.33\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 168.89: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72 average Loss: 167.45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 194.75: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73 average Loss: 163.05\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 152.18: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74 average Loss: 165.06\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 163.55: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75 average Loss: 165.76\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 201.01: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 76 average Loss: 163.55\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 179.42: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 77 average Loss: 166.45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 162.17: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 78 average Loss: 156.81\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 152.47: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 79 average Loss: 162.18\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 165.50: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 80 average Loss: 160.57\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 165.57: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 81 average Loss: 161.73\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 161.04: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 82 average Loss: 158.13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 174.09: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 83 average Loss: 159.84\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 177.58: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 90 average Loss: 157.95\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 149.19: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91 average Loss: 156.02\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 127.27: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 92 average Loss: 155.13\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 145.13: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 93 average Loss: 154.09\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 163.07: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 94 average Loss: 153.48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 184.44: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 95 average Loss: 155.73\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 143.25: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 96 average Loss: 154.50\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 146.29: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 97 average Loss: 155.67\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 151.82: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 98 average Loss: 152.78\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 166.37: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 99 average Loss: 151.56\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 154.37: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 100 average Loss: 151.28\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 151.74: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 101 average Loss: 152.10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 152.25: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 102 average Loss: 149.41\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 149.48: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 103 average Loss: 152.32\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 150.61: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 104 average Loss: 150.47\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 183.94: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 105 average Loss: 147.51\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 154.02: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 106 average Loss: 148.12\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 152.17: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107 average Loss: 148.15\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 156.11: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108 average Loss: 147.79\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 171.33: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109 average Loss: 146.63\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 137.81: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110 average Loss: 149.54\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 155.93: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111 average Loss: 149.12\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 145.32: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112 average Loss: 144.02\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 160.05: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 113 average Loss: 149.04\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "IOPub message rate exceeded.\n",
      "The notebook server will temporarily stop sending output\n",
      "to the client in order to avoid crashing it.\n",
      "To change this limit, set the config variable\n",
      "`--NotebookApp.iopub_msg_rate_limit`.\n",
      "\n",
      "Current values:\n",
      "NotebookApp.iopub_msg_rate_limit=1000.0 (msgs/sec)\n",
      "NotebookApp.rate_limit_window=3.0 (secs)\n",
      "\n",
      "Loss: 139.33: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 220 average Loss: 117.12\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 138.91: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 221 average Loss: 116.55\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 104.32: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 222 average Loss: 116.80\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 117.71: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 223 average Loss: 117.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 134.89: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 224 average Loss: 119.44\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 135.91: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 225 average Loss: 119.45\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 138.04: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 226 average Loss: 120.05\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 108.47: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 227 average Loss: 116.48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 108.73: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 228 average Loss: 115.37\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 144.40: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 229 average Loss: 116.80\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 122.90: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 230 average Loss: 118.18\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 117.63: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 231 average Loss: 117.20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 118.66: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 232 average Loss: 115.43\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 104.42: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.77it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 233 average Loss: 115.26\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 130.52: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 234 average Loss: 118.48\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 106.22: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 235 average Loss: 114.43\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 131.60: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 236 average Loss: 115.40\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 126.64: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 237 average Loss: 114.81\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 128.41: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 238 average Loss: 115.24\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 113.79: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 239 average Loss: 114.66\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 94.17: 100%|████████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 240 average Loss: 115.97\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 114.18: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 241 average Loss: 116.87\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 137.02: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 242 average Loss: 115.15\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 150.75: 100%|███████████████████████████████████████████| 61/61 [00:10<00:00,  5.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 243 average Loss: 117.62\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 110.83:  70%|██████████████████████████████▎            | 43/61 [00:07<00:03,  5.73it/s]IOPub message rate exceeded.\n",
      "The notebook server will temporarily stop sending output\n",
      "to the client in order to avoid crashing it.\n",
      "To change this limit, set the config variable\n",
      "`--NotebookApp.iopub_msg_rate_limit`.\n",
      "\n",
      "Current values:\n",
      "NotebookApp.iopub_msg_rate_limit=1000.0 (msgs/sec)\n",
      "NotebookApp.rate_limit_window=3.0 (secs)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "train_discrete_model.train_ex.run(\n",
    "    \"train_branched_model\",\n",
    "    config_updates={\n",
    "        \"model\": model,\n",
    "        \"diffuser\": diffuser,\n",
    "        \"data_loader\": data_loader,\n",
    "        \"class_time_to_branch_index\": class_time_to_branch_tensor,\n",
    "        \"num_epochs\": 300,\n",
    "        \"learning_rate\": 1e-3,\n",
    "        \"t_limit\": t_limit\n",
    "    }\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "71f84775",
   "metadata": {},
   "source": [
    "### Show generated distributions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "6726f308",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████████████████| 1000/1000 [00:10<00:00, 92.21it/s]\n"
     ]
    }
   ],
   "source": [
    "samples = {}\n",
    "for class_to_sample in classes:\n",
    "    sample = generate.generate_discrete_branched_samples(\n",
    "        model, diffuser, class_to_sample, class_time_to_branch_tensor,\n",
    "        t_limit=t_limit, verbose=True\n",
    "    ).cpu().numpy()\n",
    "    samples[class_to_sample] = sample"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "afa6bbb3",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Class 0\n"
     ]
    },
    {
     "data": {
      "image/png": "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/uRPePzjH8+jH/1o1qxZQ1XzGX700UfzO7/zOzz96U/nkY98JJs2beLXf/3XOeSQQ3jTm94EwJVXXsmhhx7KK17xCg477DBe+MIX8qMf/egux/70pz/Nk570JI488khe9KIXccstzXnDySefzMqVKznssMN4wxve0KdnYkY2AYckWZFkH5pEz4buSknuCzwD+ESf45M0Bnr9Zb2tdxpwXn8jlLTI9DQcPsnzk3wD+Bea3kA9b9tuby9paUyYBJIG4Fd+5Ve46qqreMQjHsFrXvMaPv/5zwOwdu1aNm3axMUXX8ytt97Kueeeu3ubffbZhy984QuceOKJrFq1itNPP52LL76Ys846ixtuuAGAyy67jDVr1nDRRRex33778e53v/tOx73++us59dRT+bd/+ze++tWvMjExwV/+5V/yve99j4997GNs3bqViy66aHdiaZhU1U5gLc0XqkuBD1fV1iQnJjmxo+rzgU9X1Q8HEaekRa/XSepfRzMv2XX9DE7SotPTcPiq+lhVHQo8D3jLTLZtt19fVRNVNbF06dLZxippBJgEkgbg3ve+NxdeeCHr169n6dKlvPjFL+ass87i3//933nCE57AYx7zGD772c+ydevW3ds897nPBeAxj3kMj3rUo3jQgx7E3e9+dx760Idy1VXNjzwHHnggT3nKUwB46Utfyhe/+MU7HfeCCy7gkksu4SlPeQpHHHEE73vf+/jWt77Ffvvtx7777surXvUqzjnnHO55z3v26ZmYmaraWFWPqKqHVdWftuvWVdW6jjpnVdXqwUUpaZGb9pf1JMtoEtLr2AN/eZfUg5kMh6eqvgA8LMkBM91W0nhwTiBpQJYsWcLRRx/N0UcfzWMe8xj+9m//losuuojNmzdz4IEHcsopp/DjH/94d/1dQ8fudre77b6/a3nnzp0AJHf+wad7uap41rOexYc+dNfpcr7yla/wmc98hrPPPpt3vetdfPazn523xypJi0gvv6y/A3hjVd3R3Q7faSPnJ5M0vd3D4YGraYbDv6SzQpKHA/9TVZXkSGAf4Abgxum2lTR+7AkkDcBll13Gf//3f+9e3rJlC7/wC78ANPMD3XLLLXzkIzOfQ/Tb3/42X/rSlwD40Ic+xFOf+tQ7lT/xiU/kP//zP9m2bRsAP/rRj7j88su55ZZbuOmmmzjuuON4xzvewZYtW2b5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\n",
      "text/plain": [
       "<Figure size 1440x1440 with 16 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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zESfAJgnJzr4eWeSF44/fmGSv+xTDgADoU8AMBN9AmCeHMufc39rkg8neXRVXV9V35vkV5N8XVX9a5KvG38OwIOQPgHATPQJgIW14mg3aK09b5qrntm5FgCWIH0CgJnoEwALa85P7gwAAADAwjD4AQAAABgogx8AAACAgTL4AQAAABioo57cuadDh1tuv+dA18w9e/d3zdu8flXXvCR52Knru2f29tmb7uqat351/6fWQ7au6565FNz8odd1zTv9y17WNS9J3vqmn+ya9/dX39o1L0m+72kP7Z7Z0+oV5vBJsnf/oVz+hT1dM8896+SueSuWd41Lkmxc23fNXL2yf5H7DhzqmvfL7/1s17wkefUzH9U9s7dnPOKU7pl7Lr24a97mCy7qmpf0r/FT193RNS9JHr9jY9e8Uzeu6Zq3cnl1zVuq1q5cnsdt77uu37e/7/o2F/YdPNw1b8tJ/fd5rr51b9e86+64p2te0n8fpVb177ffft6O7pk33X5f17wzNvVd35LkzZdf2zXvGdv799tN61Z2zVu2rPO6PkOcPQ0AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABgogx8AAACAgTL4AQAAABioFfN5Z4cPt9y1/2DXzA9+YVfXvK96+LaueUmyfnXfH/OyZdU1L0mWVd/Mk9b0f2rdt/9Q17y79/V9LibJ1g2ru2fedPt9XfPe+qaf7JqXJM974S91zfvse3+za16SHDx0uGveiuXm5nPh3gOHcsXOO7pmLu+8vp13zqaueUmyeuXy7pm9/cPndnbNe/UzH9U1by5cdcOd3TMfe9bJ3TOv3XVP17w9l17cNS9JNl9wUde8uaiRpeHA4ZZdd+3rmtl/y7q/DWtXds3bf7DvdlGSrFvVt5ft2Liua16SrFnZd/ttb+f9kyRZvrz/M/L0jX33Ud58+bVd85Lk+U85u2veX33qxq55SfKkMzd3zVu2rO/+6OHDbfr76npPAAAAACwaBj8AAAAAA2XwAwAAADBQBj8AAAAAA2XwAwAAADBQBj8AAAAAA3XUwU9VvbGqbq2q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\n",
      "text/plain": [
       "<Figure size 1440x720 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# For simplicity, sample a lot of inputs for the real data\n",
    "data, targets = [], []\n",
    "for _ in range(len(classes)):\n",
    "    x, y = next(iter(data_loader))\n",
    "    data.append(x.cpu().numpy())\n",
    "    targets.append(y.cpu().numpy())\n",
    "data = np.concatenate(data)\n",
    "targets = np.concatenate(targets)\n",
    "\n",
    "for class_to_sample in classes:\n",
    "    print(\"Class %s\" % class_to_sample)\n",
    "    real = data[targets == class_to_sample]\n",
    "    sample = samples[class_to_sample]\n",
    "    \n",
    "    # Decide which features to plot\n",
    "    num_features = min(input_shape[0], 16)\n",
    "    feature_inds = np.flip(np.argsort(np.std(real, axis=0)))[:num_features]\n",
    "    # feature_inds = np.random.choice(input_shape[0], size=num_features, replace=False)\n",
    "    \n",
    "    num_cols = 4\n",
    "    num_rows = int(np.ceil(num_features / num_cols))\n",
    "    num_bins = 20\n",
    "\n",
    "    # Plot feature values\n",
    "    fig, ax = plt.subplots(ncols=num_cols, nrows=num_rows, figsize=(num_cols * 5, num_rows * 5))\n",
    "    for i, f_i in enumerate(feature_inds):\n",
    "        r, c = i // num_cols, i % num_cols\n",
    "        real_vals = real[:, f_i]\n",
    "        sample_vals = sample[:, f_i]\n",
    "        all_vals = np.concatenate([real_vals, sample_vals])\n",
    "        bins = np.linspace(np.min(all_vals), np.max(all_vals), num_bins)\n",
    "        ax[r][c].hist(real_vals, bins=bins, color=\"royalblue\", label=\"Real\", density=True, alpha=0.5)\n",
    "        ax[r][c].hist(sample_vals, bins=bins, color=\"darkorange\", label=\"Samples\", density=True, alpha=0.5)\n",
    "        ax[r][c].set_title(\"Feature %d\" % f_i)\n",
    "    ax[0][0].legend()\n",
    "    plt.show()\n",
    "\n",
    "    # Compute and plot correlations\n",
    "    real_corrs = np.empty((num_features, num_features))\n",
    "    sample_corrs = np.empty_like(real_corrs)\n",
    "    for i, f_i in enumerate(feature_inds):\n",
    "        real_corrs[i, i] = 1\n",
    "        sample_corrs[i, i] = 1\n",
    "        for j in range(i):\n",
    "            f_j = feature_inds[j]\n",
    "            real_corrs[i, j] = scipy.stats.pearsonr(real[:, f_i], real[:, f_j])[0]\n",
    "            real_corrs[j, i] = real_corrs[i, j]\n",
    "            sample_corrs[i, j] = scipy.stats.pearsonr(sample[:, f_i], sample[:, f_j])[0]\n",
    "            sample_corrs[j, i] = sample_corrs[i, j]\n",
    "\n",
    "    fig, ax = plt.subplots(ncols=3, figsize=(20, 10))\n",
    "    ax[0].imshow(real_corrs, cmap=\"Blues\", vmin=0, vmax=1)\n",
    "    ax[0].set_title(\"Real correlations\")\n",
    "    ax[1].imshow(sample_corrs, cmap=\"Blues\", vmin=0, vmax=1)\n",
    "    ax[1].set_title(\"Sample correlations\")\n",
    "    ax[2].imshow(np.abs(real_corrs - sample_corrs), cmap=\"Blues\", vmin=0, vmax=1)\n",
    "    ax[2].set_title(\"Absolute difference in correlations\")\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.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
