{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Some training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'val_dataloader' to speed up the dataloader worker initialization.\n",
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/call.py:54: Detected KeyboardInterrupt, attempting graceful shutdown...\n",
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, PinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_simple_dataset\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "    \n",
    "#for beta in [0.1, 0.5, 1.0, 2.0, 4.0, 10.]:\n",
    "    \n",
    "for beta in [0.1, 0.5, 1.0, 2.0, 4.0, 10., 20.]:\n",
    "\n",
    "    sde =  PinnedBrownSDE(N = 1000, beta_const=beta)\n",
    "    denoiser = MLPDenoiser(hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout)\n",
    "    diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "    diffuser.to('cpu')\n",
    "    \n",
    "    # Instantiate Trainer\n",
    "    trainer = Trainer(max_epochs=10)\n",
    "\n",
    "    # Train model\n",
    "    trainer.fit(diffuser, get_simple_dataset())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Getting started"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ToyDiffusion(\n",
       "  (model): MLPDenoiser(\n",
       "    (layers): ModuleList(\n",
       "      (0): Linear(in_features=3, out_features=256, bias=True)\n",
       "      (1-3): 3 x Linear(in_features=256, out_features=256, bias=True)\n",
       "    )\n",
       "    (out): Linear(in_features=256, out_features=2, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, PinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "\n",
    "\n",
    "sde =  PinnedBrownSDE(N = 100, beta_const=1.)\n",
    "denoiser = MLPDenoiser(hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout)\n",
    "diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "diffuser.to('cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<src.diffusion.sampling.samplers.PC_Sampler at 0x19aed14b0>"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "diffuser.sampler # does that print the sampler that you request ?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1000 [00:00<?, ?it/s]/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  # dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "100%|██████████| 1000/1000 [00:01<00:00, 873.35it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=1.)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'torch' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[1;32m/Users/teoreu/git/francisco_sde/src/notebook.ipynb Cell 7\u001b[0m line \u001b[0;36m1\n\u001b[0;32m----> <a href='vscode-notebook-cell:/Users/teoreu/git/francisco_sde/src/notebook.ipynb#W6sZmlsZQ%3D%3D?line=0'>1</a>\u001b[0m trainset \u001b[39m=\u001b[39m torch\u001b[39m.\u001b[39mload(os\u001b[39m.\u001b[39mpath\u001b[39m.\u001b[39mjoin(RAW_DATA_PATH,\u001b[39m\"\u001b[39m\u001b[39mgauss_mixture_dim_3/trainset.py\u001b[39m\u001b[39m\"\u001b[39m))\n",
      "\u001b[0;31mNameError\u001b[0m: name 'torch' is not defined"
     ]
    }
   ],
   "source": [
    "trainset = torch.load(os.path.join(RAW_DATA_PATH,\"gauss_mixture_dim_3/trainset.py\"))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PosixPath('/Users/teoreu/git/francisco_sde/src/data/raw')"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "RAW_DATA_PATH"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OzbykzsPJ3eEJSJnMbPw1ikPaW7EVTMJJly5rRSVG1G57cRKbSKiWOSK+MMjllFTuNycs52a+zcDkQSktAxN6wXHwIOI3MjqpbUcK7l8N+mZMXXCKJ+I3MrqpbXJssrIKAxEEpSR9RNWt3RXg08eRKSES2udjYFIAjMiKje7L4kezNIQkQgurXU29hGhuMzuS6KV1Xs6EJF72d3/iOJjIEJxOTGlacfGe0TkXlZu4EfqMRChuJyY0nRqloaInCtRdqpNRKwRobic2C3QiVkaInI+NkF0JgYiFJcTuwU6MUtDRO7ApbXOw6kZUuS0lCYLz4iIEgczIiTESSlNJ2ZpiIhIG7Z4J9diHxEiImdii3dKCk7K0hARkTYMRMjVWHhGRORuLFYlIiIi2zAQISIiItuYGogsWLAAl1xyCXJyclBQUIDJkydjz549Zr4lERERuYipgcjbb7+NyspKbN26FevWrUNrayuuuOIKNDU1mfm2RERE5BKWLt89evQoCgoK8Pbbb+Ob3/ym4uu5fJeIiMh91Ny/La0R8fv9AIAePdjxkoiIiCxcvhsKhXDvvfeirKwMgwcPjvmaYDCIYDDY8f+BQMCq0yMiIiIbWJYRqaysRG1tLVatWiX7mgULFsDn83X8KS4utur0iIiIyAaW1IhMnz4da9aswTvvvIN+/frJvi5WRqS4uJg1IkRERC7imBbvkiThhz/8IVavXo233norbhACAOnp6UhPTzfzlIiIiMhBTA1EKisrsWLFCqxZswY5OTloaGgAAPh8PmRmZpr51kREROQCpk7NeDyxNx9btmwZbr/9dsXv5/JdIiIi93HU1AwRERGRHO41Q0RERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2YSBCREREtmEgQkRERLZhIEJERES2sSQQefbZZ1FSUoKMjAyMGjUK27Zts+JtiYiIyOFMD0RefvllzJo1C3PnzkV1dTUuvvhiXHnllfjss8/MfmsiIiJyONMDkSeffBIVFRW44447MGjQICxZsgRZWVn47W9/a/ZbExERkcOZGoi0tLTgvffeQ3l5+Vdv6PWivLwcW7Zs6fL6YDCIQCDQ6Q8RERElLlMDkWPHjqGtrQ1nn312p6+fffbZaGho6PL6BQsWwOfzdfwpLi428/SIiIjIZo5aNTNnzhz4/f6OP4cOHbL7lIiIiMhE3cw8eH5+PlJSUnDkyJFOXz9y5AgKCwu7vD49PR3p6elmnhIRERE5iKkZkbS0NAwfPhwbNmzo+FooFMKGDRswZswYM9+aiIiIXMDUjAgAzJo1C7fddhtGjBiBkSNH4umnn0ZTUxPuuOMOs9+aiIiIHM70QOS73/0ujh49ip/97GdoaGjAkCFDsHbt2i4FrERERJR8PJIkSXafhJxAIACfzwe/34/c3Fy7T4eIiIgEqLl/O2rVDBERESUXBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQbBiJERERkGwYiREREZBsGIkRERGQb0wKRgwcPYtq0aejXrx8yMzMxYMAAzJ07Fy0tLWa9JREREblMN7MOvHv3boRCITz33HMYOHAgamtrUVFRgaamJjzxxBNmvS0RERG5iEeSJMmqN3v88cexePFifPzxx0KvDwQC8Pl88Pv9yM3NNfnsiIiIyAhq7t+mZURi8fv96NGjh+zfB4NBBIPBjv8PBAJWnBYRERHZxLJi1Y8++gjPPPMM7rzzTtnXLFiwAD6fr+NPcXGxVadHRERENlAdiFRVVcHj8cT9s3v37k7fU1dXh4kTJ+LGG29ERUWF7LHnzJkDv9/f8efQoUPqPxERERG5huoakaNHj6KxsTHua/r374+0tDQAwOHDh3HZZZdh9OjR+N3vfgevVzz2YY0IERGR+5haI9KrVy/06tVL6LV1dXUYN24chg8fjmXLlqkKQoiIiCjxmVasWldXh8su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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_train = trainset[:256]\n",
    "plt.scatter(x_train[:,0].cpu().numpy(), x_train[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [],
   "source": [
    "evo = diffuser.forward_diffusion(x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_plot = evo[-2].cpu().numpy()\n",
    "plt.scatter(x_plot[:,0], x_plot[:,1])\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_t = diffuser.noise_x0(x_train, torch.ones(size=(x_train.size()[0],)))[0]\n",
    "plt.scatter(x_t[:,0], x_t[:,1])\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "MovieWriter imagemagick unavailable; using Pillow instead.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1002, 256, 2])\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from src.evaluation.gif_func import save_2d_trajectory_as_gif\n",
    "save_2d_trajectory_as_gif(\n",
    "    evo[100:1000].cpu().numpy(), \"pbm_forward_2.gif\", s=10, alpha=0.5, marker=\"o\", dpi=100, fps=40\n",
    ")\n",
    "print(evo.size())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'val_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking DataLoader 0: 100%|██████████| 2/2 [00:00<00:00, 98.68it/s]hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  # dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "100%|██████████| 1000/1000 [00:01<00:00, 910.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                                                           \r"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'train_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:37<00:00, 84.45it/s, v_num=15]hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "100%|██████████| 1000/1000 [00:01<00:00, 916.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:48<00:00, 63.89it/s, v_num=15]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=10` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:48<00:00, 63.86it/s, v_num=15]\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_simple_dataset\n",
    "\n",
    "\n",
    "# Instantiate Trainer\n",
    "trainer = Trainer(max_epochs=10)\n",
    "\n",
    "# Train model\n",
    "trainer.fit(diffuser, get_simple_dataset())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:01<00:00, 928.27it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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Ly/XOeecowsuuECLFy/WyZMnvS4tZU8//bSGDx+uvLw8VVVVqba21uuSHLFs2TL9yZ/8iQoKClRcXKwbb7xRH330kddluWb58uUKhUJasGCB16U4Zt++fZoxY4YGDhyoc845R5dccon++7//2+uyHBGNRvXggw+2u5Y88sgjPT4/x08CHVSuv/56nT59Wm+88Ybee+89XXbZZbr++uvV1NTkdWmO+NWvfqVvfvObuu222/T+++/r3Xff1S233OJ1WY677777NGTIEK/LcNT27dvV1tamZ555Rh9++KF+/OMfa9WqVfre977ndWkpeemll7Rw4UItXrxYdXV1uuyyy3Tttdfq4MGDXpfWa2+99ZbmzZunzZs3a8OGDTp16pSuueYaHTt2zOvSHLdlyxY988wzuvTSS70uxTFffPGFJkyYoL59++q1117T1q1b9aMf/Uj9+/f3ujRHrFixQitXrtRPf/pTbdu2TStWrNDjjz+up556yuvSnGMF1KFDhyxJ1ttvvx1/LRKJWJKsDRs2eFiZM06dOmUNHTrU+tnPfuZ1Ka569dVXrZEjR1offvihJcn6wx/+4HVJrnn88cet8vJyr8tISWVlpTVv3rz459Fo1BoyZIi1bNkyD6tyx8GDBy1J1ltvveV1KY5qaWmxLrroImvDhg3Wn//5n1vz58/3uiRH3H///dbEiRO9LsM1U6dOtf7+7/++3Ws33XSTdeutt3pUkfMCO6IycOBAXXzxxfqnf/onHTt2TKdPn9Yzzzyj4uJijR071uvyeq2urk779u1TVlaWRo8erdLSUl133XVqaGjwujTHHDhwQHPmzNE///M/Kz8/3+tyXNfc3KwBAwZ4XUbSTp48qffee0+TJk2Kv5aVlaVJkyappqbGw8rc0dzcLEm+/H/VnXnz5mnq1Knt/j8GwW9/+1tdccUVuvnmm1VcXKzRo0fr2Wef9bosx3z961/Xxo0btWPHDknS+++/r9///ve67rrrPK7MOb5/KGEioVBIr7/+um688UYVFBQoKytLxcXFqq6uDsSQ36effipJevjhh/Xkk09q+PDh+tGPfqQrr7xSO3bs8P1F1LIszZo1S3feeaeuuOIK7d692+uSXPXJJ5/oqaee0hNPPOF1KUn7/PPPFY1GNXjw4HavDx48WNu3b/eoKne0tbVpwYIFmjBhgkaNGuV1OY5Zt26d6urqtGXLFq9Lcdynn36qlStXauHChfre976nLVu26K677lJOTo5mzpzpdXm9tmjRIkUiEY0cOVLZ2dmKRqNaunSpbr31Vq9Lc4zvRlQWLVqkUCjU7cf27dtlWZbmzZun4uJivfPOO6qtrdWNN96oadOmqbGx0evTSMju+bW1tUmSvv/97+uv/uqvNHbsWK1evVqhUEj/8i//4vFZJGb3/J566im1tLTogQce8LrkpNg9v7Pt27dPU6ZM0c0336w5c+Z4VDnsmDdvnhoaGrRu3TqvS3HM3r17NX/+fL344ovKy8vzuhzHtbW1acyYMXrsscc0evRo3X777ZozZ45WrVrldWmO+OUvf6kXX3xRP//5z1VXV6cXXnhBTzzxhF544QWvS3OM71roHzp0SIcPH+72mBEjRuidd97RNddcoy+++KLdI68vuugizZ49W4sWLXK71JTYPb93331XV199td555x1NnDgx/rWqqipNmjRJS5cudbvUlNg9v7/+67/W+vXrFQqF4q9Ho1FlZ2fr1ltvNfYfod3zy8nJkSTt379fV155pcaNG6c1a9YoK8t39w46efKk8vPz9a//+q/tdp3NnDlTR48e1csvv+xdcQ769re/rZdffllvv/22ysvLvS7HMf/2b/+mv/zLv1R2dnb8tWg0qlAopKysLLW2trb7mt8MGzZMkydP1s9+9rP4aytXrtSjjz6qffv2eViZM8rKyrRo0SLNmzcv/tqjjz6qtWvXBmZE03dTP0VFRSoqKurxuOPHj0tSpwt/VlZWfDTCRHbPb+zYscrNzdVHH30UDyqnTp3S7t27NWzYMLfLTJnd8/uHf/gHPfroo/HP9+/fr2uvvVYvvfSSqqqq3CyxV+yen3RmJOWqq66Kj4b5MaRIUk5OjsaOHauNGzfGg0pbW5s2btyob3/7294W5wDLsvSd73xHv/nNb/Tmm28GKqRI0je+8Q198MEH7V677bbbNHLkSN1///2+DimSNGHChE7byXfs2GH0dTIZx48f73TtyM7ONvrvXNI8XcrrokOHDlkDBw60brrpJqu+vt766KOPrHvvvdfq27evVV9f73V5jpg/f741dOhQ69///d+t7du3W7Nnz7aKi4utI0eOeF2a43bt2hWoXT+fffaZdeGFF1rf+MY3rM8++8xqbGyMf/jRunXrrNzcXGvNmjXW1q1brdtvv93q16+f1dTU5HVpvTZ37lwrHA5bb775Zrv/T8ePH/e6NNcEaddPbW2t1adPH2vp0qXWxx9/bL344otWfn6+tXbtWq9Lc8TMmTOtoUOHWr/73e+sXbt2Wb/+9a+tQYMGWffdd5/XpTkmsEHFsixry5Yt1jXXXGMNGDDAKigosMaNG2e9+uqrXpflmJMnT1r33HOPVVxcbBUUFFiTJk2yGhoavC7LFUELKqtXr7YkdfnhV0899ZR1/vnnWzk5OVZlZaW1efNmr0tyRKL/T6tXr/a6NNcEKahYlmWtX7/eGjVqlJWbm2uNHDnS+sd//EevS3JMJBKx5s+fb51//vlWXl6eNWLECOv73/++1dra6nVpjvHdGhUAAJA5/DkpDgAAMgJBBQAAGIugAgAAjEVQAQAAxiKoAAAAYxFUAACAsQgqAADAWAQVAABgLIIKAAAwFkEFAAAYi6ACAACMRVABAADG+v9o/iSGTcryfwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "evo = diffuser.sample(eta=1.)\n",
    "x_plot = evo.cpu().numpy()\n",
    "plt.scatter(x_plot[:,0], x_plot[:,1])\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# VP Process sanity check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "ToyDiffusion(\n",
       "  (model): MLPDenoiser(\n",
       "    (layers): ModuleList(\n",
       "      (0): Linear(in_features=3, out_features=256, bias=True)\n",
       "      (1-3): 3 x Linear(in_features=256, out_features=256, bias=True)\n",
       "    )\n",
       "    (out): Linear(in_features=256, out_features=2, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# VP Proccess\n",
    "\n",
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, PinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "\n",
    "\n",
    "sde =  VPSDE()\n",
    "denoiser = MLPDenoiser(hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout)\n",
    "diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "diffuser.to('cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1087.30it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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5kTa/PnPfzadO3c206dPNxUVFWbx4sUmPT3drFu3LoGvJD5WrlxpMjIyzL//+7+bvXv3milTppju3bubqqqqZHct5tauXWvuu+8+87vf/c5IMi+++GLU/QsXLjQej8e89NJL5t133zU33nijKSgoMF988UWkzahRo8zll19utm7dav7nf/7H9O/f34wfPz7Br6T9SkpKzLJly0x5ebnZvXu3+da3vmX69u1rPvvss0ibqVOnmvz8fLNhwwbzzjvvmGHDhpnhw4dH7m/J746d/P73vzevvPKK+eMf/2j2799vfvSjH5mOHTua8vJyY0zijgeB5wxr1641AwYMMHv37m0QeJ588knTo0cPU1tbG7lt1qxZ5pJLLolc/4d/+AczevToqOe86qqrzPe///249z3eVq9ebVwulzlx4oQxhuOxaNEiU1BQELmeysdj2bJljQaetWvXmrS0NBMIBCK3LVmyxLjd7shx+uEPf2i++tWvRj3ulltuMSUlJXHtcyIMHTrUlJWVRa7X1dWZPn36mAULFiSxV/F3duCpr683Xq/XPPzww5Hbjh07ZjIzM80LL7xgjDGmoqLCSDJvv/12pM2rr75qXC6X+fjjjxPW93g4evSokWQ2b95sjDn92jt27GhWrVoVafP+++8bScbv9xtjWva7Y3c9evQw//Zv/5bQ48GU1v+pqqrSlClT9J//+Z/q3Llzg/v9fr+uueYaZWRkRG4rKSnR/v379emnn0baFBcXRz2upKREfr8/vp2Ps+rqaj333HMaPny4OnbsKCm1j4ckBYNBZWdnR66n+vFojN/v18CBA5Wbmxu5raSkRKFQSHv37o20ceIxOXHihHbs2BH12tLS0lRcXGz719ZaBw8eVCAQiDoWHo9HV111VeRY+P1+de/eXVdccUWkTXFxsdLS0rRt27aE9zmWgsGgJEX+XuzYsUMnT56MOh4DBgxQ3759o45Hc787dlVXV6eVK1fq888/l8/nS+jxIPDo9PzypEmTNHXq1KhfuDMFAoGogy0pcj0QCJyzTfh+u5k1a5a6dOminj176tChQ1q9enXkvlQ8HmF/+tOftHjxYn3/+9+P3JbKx6Mp7TkmoVBIX3zxRWI6Ggd//etfVVdXl1Lvd1PCr/dcxyIQCCgnJyfq/g4dOig7O9vWx6u+vl733HOPvv71r6uoqEjS6deakZHRoO7t7OPR3O+O3bz33nvq2rWrMjMzNXXqVL344osqLCxM6PFwdOCZPXu2XC7XOS/79u3T4sWLdfz4cc2ZMyfZXY6rlh6PsJkzZ2rXrl16/fXXlZ6erjvuuEPGQRtzt/Z4SNLHH3+sUaNG6bvf/a6mTJmSpJ7HT1uOCYDGlZWVqby8XCtXrkx2V5Lukksu0e7du7Vt2zaVlpZq4sSJqqioSGgfOiT0pyXYjBkzNGnSpHO2ufDCC7Vx40b5/f4G5+644oordNttt+nZZ5+V1+ttUDUevu71eiP/baxN+P5ka+nxCOvVq5d69eqliy++WJdeeqny8/O1detW+Xy+lDweR44c0YgRIzR8+HA9/fTTUe2ccDyk1h+Tc/F6vQ1WJbX0mLjdbnXq1KmFvbaeXr16KT093fLvdyKEX29VVZXy8vIit1dVVWnQoEGRNkePHo163KlTp1RdXW3b4zVt2jS9/PLLevPNN3X++edHbvd6vTpx4oSOHTsWNapx5mejJb87dpORkaH+/ftLkoYMGaK3335bjz/+uG655ZbEHY9YFSDZ2Ycffmjee++9yOW1114zksxvf/tbc/jwYWPMl0Wp4aJdY4yZM2dOg6LUb3/721HP7fP5bF+UaszpYyTJvPHGG8aY1DseH330kbnooovMrbfeak6dOtXg/lQ7Hmdqrmj5zFVJTz31lHG73aampsYYc7pouaioKOpx48ePd0zR8rRp0yLX6+rqzHnnnZeyRcuPPPJI5LZgMNho0fI777wTafPaa6/Zsmi5vr7elJWVmT59+pg//vGPDe4PF+n+9re/jdy2b9++Rot0z/W7Y3cjRowwEydOTOjxIPA04uDBgw1WaR07dszk5uaaCRMmmPLycrNy5UrTuXPnBsuOO3ToYB555BHz/vvvm3nz5tly2fHWrVvN4sWLza5du8wHH3xgNmzYYIYPH2769esX+XCl0vH46KOPTP/+/c11111nPvroI1NZWRm5hKXS8Qj78MMPza5du8z8+fNN165dza5du8yuXbvM8ePHjTFfLiUdOXKk2b17t1m3bp3p3bt3o8vSZ86cad5//33zxBNPOGpZemZmplm+fLmpqKgwd911l+nevXvUShOnOH78eOT9l2QeffRRs2vXLvPhhx8aY04vS+/evbtZvXq12bNnj7npppsaXZb+ta99zWzbts289dZb5qKLLrLlsvTS0lLj8XjMpk2bov5W/O1vf4u0mTp1qunbt6/ZuHGjeeeddxps+9GS3x07mT17ttm8ebM5ePCg2bNnj5k9e7ZxuVzm9ddfN8Yk7ngQeBrRWOAxxph3333XXH311SYzM9Ocd955ZuHChQ0e+5vf/MZcfPHFJiMjw3z1q181r7zySoJ6HTt79uwxI0aMMNnZ2SYzM9N85StfMVOnTjUfffRRVLtUOR7Lli0zkhq9nClVjkfYxIkTGz0m4VFAY4z54IMPzA033GA6depkevXqZWbMmGFOnjwZ9TxvvPGGGTRokMnIyDAXXnihWbZsWWJfSBwtXrzY9O3b12RkZJihQ4earVu3JrtLcfHGG280+lmYOHGiMeb0qMePf/xjk5ubazIzM811111n9u/fH/Ucn3zyiRk/frzp2rWrcbvd5s4774yEZztp6m/FmZ/rL774wvzzP/+z6dGjh+ncubP5+7//+6h/QBnTst8du/je975nLrjgApORkWF69+5trrvuukjYMSZxx8NljIOqUAEAABrh6FVaAAAAEoEHAACkAAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwPAIPAABwvP8PIgHJLh+8uOYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=0.2)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'val_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking DataLoader 0: 100%|██████████| 2/2 [00:00<00:00, 80.80it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 1145.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                                                           \r"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'train_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:31<00:00, 99.38it/s, v_num=19]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1195.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:47<00:00, 65.62it/s, v_num=19] "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=10` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:47<00:00, 65.59it/s, v_num=19]\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_simple_dataset\n",
    "\n",
    "\n",
    "# Instantiate Trainer\n",
    "trainer = Trainer(max_epochs=10)\n",
    "\n",
    "# Train model\n",
    "trainer.fit(diffuser, get_simple_dataset())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 1065.64it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=0.2)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBM sanity check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ToyDiffusion(\n",
       "  (model): MLPDenoiser(\n",
       "    (layers): ModuleList(\n",
       "      (0): Linear(in_features=3, out_features=256, bias=True)\n",
       "      (1-3): 3 x Linear(in_features=256, out_features=256, bias=True)\n",
       "    )\n",
       "    (out): Linear(in_features=256, out_features=2, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# PBM Proccess\n",
    "\n",
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, PinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "\n",
    "\n",
    "sde =  PinnedBrownSDE()\n",
    "denoiser = MLPDenoiser(hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout)\n",
    "diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "diffuser.to('cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1000 [00:00<?, ?it/s]/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "  0%|          | 1/1000 [00:00<02:10,  7.68it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:01<00:00, 866.33it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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RXBC7at0rjLlvHnzlJOTo06dOqmkpESffPKJX5va2lpNnjxZGRkZyszM1PTp03XixIko9CA4oR7Pp59+2uxcNd1efPFFX7uWHt+wYUMsuhRQOP/2V199dbN+/PSnP/Vrc/DgQY0bN06dO3dWr169dO+99+rs2bPR7EqrQu1nbW2t7rzzTg0cOFCdOnXSt771Ld11113yeDx+7axwTpctW6Y+ffooPT1dRUVFqqqqarX9iy++qEGDBik9PV1Dhw7VG2+84fd4MO/ZeAilnytXrtR3vvMddevWTd26dVNJSUmz9lOnTm127kpLS6PdjTaF0s9nnnmmWR/S09P92lj1fEqh9bWlzx2Hw6Fx48b52kTknBo0M2/ePPPEE0+Y2bNnG6fT2Wb7Y8eOmZKSEvPCCy+YPXv2mMrKSlNYWGhGjBjh1653795m4cKFprq62nc7ceJElHoRnFD7aowxS5YsMU6n0/zud78zf//73833vvc907dvX/P111/72pSWlprLL7/cvPfee+Z//ud/zIABA8ykSZOi1Iu2hXo8Z8+e9TtP1dXVZsGCBebiiy82x48f97WTZNasWePX7vx/h3gI59/+qquuMmVlZX798Hg8vsfPnj1rhgwZYkpKSswHH3xg3njjDZOVlWXKy8uj3Z2AQu3nRx99ZL7//e+b1157zezbt89s2rTJXHbZZeamm27yaxfvc7phwwbTsWNHs3r1avPxxx+bsrIyk5mZaWpqalps/84775jU1FTz6KOPml27dpkHHnjAdOjQwXz00Ue+NsG8Z2Mt1H7+6Ec/MsuWLTMffPCB2b17t5k6dapxOp3miy++8LW59dZbTWlpqd+5q62tjVWXWhRqP9esWWMyMjL8+uB2u/3aWPF8GhN6X48ePerXz507d5rU1FSzZs0aX5tInFMCnVasWbMm6C//C1VVVRlJ5rPPPvNt6927t/nVr34VmYOLsGD72tjYaFwul3nsscd8244dO2bS0tLM888/b4wxZteuXUaSef/9931t/vjHPxqHw2G+/PLLiB97WyJ1PAUFBebf/u3f/LZJMq+88kqkDrXdwu3rVVddZX72s58FfPyNN94wKSkpfh+4y5cvNxkZGaa+vj4ixx6KSJ3T3/72t6Zjx47mzJkzvm3xPqeFhYXmjjvu8N1vaGgwubm5ZvHixS22/+EPf2jGjRvnt62o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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=1.)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'val_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking DataLoader 0: 100%|██████████| 2/2 [00:00<00:00, 48.88it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1126.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                                                           \r"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'train_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:25<00:00, 122.91it/s, v_num=13]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "100%|██████████| 1000/1000 [00:01<00:00, 734.47it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:38<00:00, 81.69it/s, v_num=13] "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=10` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 9: 100%|██████████| 3125/3125 [00:38<00:00, 81.65it/s, v_num=13]\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_simple_dataset\n",
    "\n",
    "\n",
    "# Instantiate Trainer\n",
    "trainer = Trainer(max_epochs=10)\n",
    "\n",
    "# Train model\n",
    "trainer.fit(diffuser, get_simple_dataset())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:01<00:00, 916.66it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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QnG0dRk7dmyLFTZt+clPfmL69u0bdV2j0V0/67fffttIMn/729+MMV9OKD59ZcQTTzxh3G63OXbsWPc1IALRttHv95srrrjCjB071jQ0NET0vWJ1DfPz880dd9wR+rqpqcmcf/757U4o/td//dewY4WFhS0mFLf3voylzrbPGGOWLl1q3G63qaysjOh7fPLJJ8blcpnXXnuty/WNRjRtPN3JkyfNsGHDzD333GOMccY1NObUvSQtLc0cOHCgw+8R72vYFQQ3Nvf3v//dvPfee6Glzu+995557733wpY8Dxs2zLz88suhr5csWWL69OljXnvtNfP++++bSZMmtboU/NJLLzWbN282b7/9trnoooviuhS8vbp8+umnZtiwYWbz5s1hr/voo4+My+Uyv/vd71qc8/XXXzcrV640H3zwgfnoo4/M//zP/5hevXqZ+fPnW96eM3W2fbt37zYLFy407777rqmpqTGvvfaaGTx4sPna174Wek1wKfi1115rtm3bZsrLy03//v3juhS8M230+/2moKDAjBgxwuzevTts6enJkyeNMfG9hmvXrjVpaWnmqaeeMjt27DC33Xab6dOnT2h12ne/+10zd+7cUPk///nP5qyzzjLLli0zO3fuNGVlZa0uBe/ofRkrnW3fkiVLTM+ePc1LL70Udq2Cf4cOHz5sfvSjH5nKykpTU1Nj3nrrLXPZZZeZiy66KObBdrRtXLBggfn9739v9uzZY7Zs2WKmTJli0tPTzfbt20NlEvkaBl111VXmxhtvbHHcjtewKwhubG769OlGUovHH/7wh1AZ/f9cIEHNzc1m3rx5JjMz06SlpZlx48aZXbt2hZ334MGDZurUqebcc881brfbzJgxIyxgiqWO6lJTU9OizcYYU1paanJyckxTU1OLc/7ud78zeXl55txzzzXnnHOOGTVqlFmxYkWrZa3W2fbt3bvXfO1rXzP9+vUzaWlpZujQoea+++4Ly3NjjDEff/yxmTBhgjn77LNNRkaGuffee8OWUcdSZ9v4hz/8odXfa0mmpqbGGBP/a/jLX/7SfOUrXzE9e/Y0+fn55p133gk9N3bsWDN9+vSw8r/5zW/MP/3TP5mePXuaf/7nfzZvvPFG2PORvC9jqTPtu/DCC1u9VmVlZcYYY44ePWquvfZa079/f9OjRw9z4YUXmlmzZrXIExNrnWnj3XffHSqbmZlprrvuOrN169aw8yXyNTTGmA8//NBIMuvXr29xLrtew2i5jInx2lgAAAALkecGAAA4CsENAABwFIIbAADgKAQ3AADAUQhuAACAoxDcAAAARyG4AQAAjkJwAwAAHIXgBgAAOArBDQAAcBSCGwAA4CgENwAAwFH+H8hFwLAfiPzNAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=1.)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GEnBMP Sanity check"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "ToyDiffusion(\n",
       "  (model): MLPDenoiser(\n",
       "    (layers): ModuleList(\n",
       "      (0): Linear(in_features=3, out_features=256, bias=True)\n",
       "      (1-3): 3 x Linear(in_features=256, out_features=256, bias=True)\n",
       "    )\n",
       "    (out): Linear(in_features=256, out_features=2, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, GenPinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "\n",
    "\n",
    "sde =  GenPinnedBrownSDE()\n",
    "denoiser = MLPDenoiser(hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout)\n",
    "diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "diffuser.to('cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1000 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Intel MKL WARNING: Support of Intel(R) Streaming SIMD Extensions 4.2 (Intel(R) SSE4.2) enabled only processors has been deprecated. Intel oneAPI Math Kernel Library 2025.0 will require Intel(R) Advanced Vector Extensions (Intel(R) AVX) instructions.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:01<00:00, 904.52it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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u8669dZbrY8++sg6depU/CPm7NmzVl5ennXPPfdYtbW11ssvv2z16tXLeu655+LH/OY3v7G6d+9uPfXUU9ahQ4es5cuXWz169LB+//vfO/FjedIHH3xg7d+/31q5cqXVu3dva//+/db+/futc+fOWZZlWZ999pk1evRoa+rUqVZNTY1VUVFhDRo0yFq6dGn8a/zxj3+0evXqZT344IPWoUOHrLVr11rdunWzKioqnPqxPO3ll1+2cnJyrI0bN1oHDx605s6da/Xt2zdh1gUy59y5c/HfE0nWf/zHf1j79++3PvjgA8uyLOuJJ56w+vbta73++uvWe++9Z33rW9+yCgsLrU8//TT+NaZNm2Z97Wtfs3bv3m39+te/tq6//npr1qxZTv1InlNeXm6FQiHr7bffTnj/+b//+7/4Md///vetYcOGWVVVVda7775rFRcXW8XFxfHHk7n22YUw45ANGzZYklr9+KLf/e531uTJk62cnBzrS1/6kvXEE09c9bVeffVV68tf/rKVnZ1tffWrX7XefPNNu34MX5g9e3ar52n79u3xY95//33rr//6r62ePXtaAwcOtBYtWmRdvnw54ets377dGjdunJWdnW0NHz7c2rBhg70/iM8888wz1rBhw6zs7GxrwoQJ1q5du5xukm9s37691d+Z2bNnW5bVMj37scces/Ly8qycnBzr1ltvtY4cOZLwNc6cOWPNmjXL6t27txUMBq3vfve78T8g0HVtvf988br06aefWj/4wQ+sfv36Wb169bL+/u//PuEPbstK7tpnh4BlWZaNHUEAAABpRc0MAAAwGmEGAAAYjTADAACMRpgBAABGI8wAAACjEWYAAIDRCDMAAMBohBkAAGA0wgwAADAaYQYAABiNMAMAAIxGmAEAAEb7f9XX9trU7tKMAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=1.)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 198 K \n",
      "--------------------------------------\n",
      "198 K     Trainable params\n",
      "0         Non-trainable params\n",
      "198 K     Total params\n",
      "0.796     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking: |          | 0/? [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'val_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking DataLoader 0: 100%|██████████| 2/2 [00:00<00:00, 43.58it/s]hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/src/diffusion/sampling/predictors.py:70: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  dt = torch.tensor(self.find_dt(t[0])).type_as(t)\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1035.99it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                                                                           "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\r"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/teoreu/git/francisco_sde/venv/lib/python3.10/site-packages/pytorch_lightning/trainer/connectors/data_connector.py:436: Consider setting `persistent_workers=True` in 'train_dataloader' to speed up the dataloader worker initialization.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:26<00:00, 115.84it/s, v_num=2]hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1090.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:35<00:00, 87.36it/s, v_num=2] "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "`Trainer.fit` stopped: `max_epochs=1` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:35<00:00, 87.31it/s, v_num=2]\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_simple_dataset\n",
    "\n",
    "\n",
    "# Instantiate Trainer\n",
    "trainer = Trainer(max_epochs=1)\n",
    "\n",
    "# Train model\n",
    "trainer.fit(diffuser, get_simple_dataset())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "hi\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:01<00:00, 902.45it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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bFnbzz17hj7kJNvnQJLefvtttbS0tP1cV1enCy+8UJdffnnI5yTj56BTBnFx8OBBk5uba+68886w23396183c+bMiU+j4mDIkCHmgQceiHj7L774wvTq1cs899xzbfd98MEHRpKpqalxoIXx9x//8R+mqKgo7DaJ/DkYO3asmT17dtvPLS0tZuDAgaaqqiro9t/73vfMlClT2t1XVlZmrrvuOkfbGS+7d+82kszKlStDblNdXW28Xm/8GhUHlZWV5owzzoh4+2T/HBhjzJw5c0xxcbFpbW0N+ngyfg4iwdBMnPz1r3/Vnj17dO2113a67ZNPPqn+/furtLRUFRUVOnDgQBxa6Jx7771X/fr101lnnaUFCxbo8OHDIbddu3atDh06pIkTJ7bdN2LECA0ePFg1NTXxaK7jfD6fcnJyOt0uET8HBw8e1Nq1a9v9/dLS0jRx4sSQf7+ampp220vSpEmTkurvLanTv/mXX36pIUOGqLCwUJdeeqnef//9eDTPUR999JEGDhyoYcOGafr06dq2bVvIbZP9c3Dw4EEtXrxYP/rRj8L2ciTj56AzDM3Eye9//3tNmjSp00X8fvCDH2jIkCEaOHCg/vnPf2ru3LnauHGj/vznP8eppbF10003aeTIkcrJydGqVatUUVGhhoYG3X///UG3b2xsVHp6uk444YR29w8YMECNjY1xaLGzNm3apIceeqjTYZlE/Rx89tlnamlp0YABA9rdP2DAAG3YsCHocxobG4Nunwx/79bWVt18882aMGFC2OGFk08+WX/4wx90+umny+fzaeHChRo/frzef//9hF34s6ysTI8//rhOPvlkNTQ0aP78+fq3f/s31dXVBR2eTebPgST95S9/0RdffKEZM2aE3CYZPwcRsd0lk2jmzp1rJIW9ffDBB+2eU19fb9LS0syf/vSnqPe3fPlyI8ls2rQpVi+h27ryHgT8/ve/Nz179jRNTU1BH3/yySdNenp6h/vHjBljfvazn8X0dXRHV96D7du3m+LiYjNz5syo9+fGz0EwO3bsMJLMqlWr2t1/2223mbFjxwZ9Tq9evcxTTz3V7r6HH37Y5OXlOdbOeLn++uvNkCFDTH19fVTPO3jwoCkuLja//OUvHWpZ/H3++ecmOzvb/O53vwv6eDJ/Dowx5qKLLjKXXHJJVM9Jxs9BMPSIROnWW28Nm2gladiwYe1+rq6uVr9+/fStb30r6v2VlZVJOnImXVxcHPXzndCV9yCgrKxMhw8f1tatW3XyySd3eDw/P18HDx7UF1980a5XZNeuXcrPz+9Os2Mq2vdg586dOv/88zV+/Hg9+uijUe/PjZ+DYPr3768ePXp0uMop3N8vPz8/qu0TxY033qiXXnpJb7zxRtRns7169dJZZ52lTZs2OdS6+DvhhBP0ta99LeRrStbPgSR98sknWrZsWdQ9msn4OQiGIBKl3Nxc5ebmRry9MUbV1dX64Q9/qF69ekW9v3Xr1kmSCgoKon6uU6J9D462bt06paWlBb16QpJGjRqlXr16afny5brsssskSRs3btS2bds0bty4Lrc51qJ5D3bs2KHzzz9fo0aNUnV1tdLSoi/NcuPnIJj09HSNGjVKy5cv17Rp0yQdGZ5Yvny5brzxxqDPGTdunJYvX66bb7657b5XX33VVX/vaBhj9OMf/1jPP/+8Xn/9dRUVFUX9O1paWvTee+/p4osvdqCFdnz55ZfavHmzrr766qCPJ9vn4GjV1dXKy8vTlClTonpeMn4OgrLdJZPsli1bFnKoYvv27ebkk082//jHP4wxxmzatMnceeed5p133jFbtmwxL7zwghk2bJg599xz493smFi1apV54IEHzLp168zmzZvN4sWLTW5urvnhD3/Yts2x74ExR7qzBw8ebFasWGHeeecdM27cODNu3DgbL6Hbtm/fboYPH26+8Y1vmO3bt5uGhoa229HbJNPn4JlnnjEZGRnm8ccfN+vXrzf//u//bk444QTT2NhojDHm6quvNvPmzWvb/q233jI9e/Y0CxcuNB988IGprKw0vXr1Mu+9956tl9Ats2bNMl6v17z++uvt/t4HDhxo2+bY92D+/PnmlVdeMZs3bzZr16413//+901mZqZ5//33bbyEmLj11lvN66+/brZs2WLeeustM3HiRNO/f3+ze/duY0zyfw4CWlpazODBg83cuXM7PJYKn4NIEEQcduWVV5rx48cHfWzLli1GknnttdeMMcZs27bNnHvuuSYnJ8dkZGSY4cOHm9tuu834fL44tjh21q5da8rKyozX6zWZmZnmlFNOMffcc0+7+pBj3wNjjPnXv/5lbrjhBtO3b1/Tp08f8+1vf7vdgTuRVFdXh6whCUjGz8FDDz1kBg8ebNLT083YsWPN6tWr2x77+te/bq655pp22//xj380X/va10x6ero59dRTzZIlS+Lc4tgJ9feurq5u2+bY9+Dmm29ue78GDBhgLr74YlNbWxv/xsfQFVdcYQoKCkx6ero58cQTzRVXXNGuxinZPwcBr7zyipFkNm7c2OGxVPgcRMJjjDFx74YBAAAQU7wDAACLCCIAAMAagggAALCGIAIAAKwhiAAAAGsIIgAAwBqCCAAAsIYgAgAArCGIAAAAawgiAADAGoIIAACwhiACAACs+X8+D5Ql8rdxeQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "xl = diffuser.sample(eta=1.)\n",
    "plt.scatter(xl[:,0].cpu().numpy(), xl[:,1].cpu().numpy())\n",
    "plt.show()\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9ccLPp+PqqoqBEEIWzKx2+1cc801CILA5s2b8fl8vPXWW7z66qt8//vfp7i4ONRLBODIkSPMmDGDffv2hdwQK9iYMIQSCFEUee+999iwYQMvv/wyNpuNlStXUl5eziWXXDImw3iKFEl9ff2ohubCBT6fb5CfxlACVoqenZ2dqiyJQi7x8fEh3+z6+vqoqqpi0qRJTJs2LeTrGS2UGZmioiISExOH7dAbbVF/vKCQiUajCQvF4+HgdDq57rrrcDqdvPXWW2Gr7iBJEmvWrMFisfD++++HejlBx4QklECIosjHH3+skovZbOaKK66gvLycyy67LCgnbcXu1mQyTUgpErfbPUi19nR576GzLnq9XiWXpKSkcd/MFV2uadOmhU3aYqSQZZmjR49y7NgxiouLh52RCbTiDRQMVeYvQtlwMBHIxO12c8MNN9DT08OWLVtISkoK9ZJOim984xu8+eabvP/++2M2qxZKTHhCCYQkSezevVsll9bWVr7whS9QVlbGlVdeeUZE4PP52Lt3L263m0WLFk04KRK73U5lZSXJyclnJDSodNQoJ+mh0vtjfZJWdLkKCwvJyckZ0/cKNmRZ5tChQ3R2dlJUVDSilvLhmihCpenm8/morKwMGy+W4eDxeLjppptobW3lnXfeISUlJdRLOim++c1v8sorr7Bz507y8/NDvZwxwWeKUAKhmPusX7+ejRs3Ul9fz6WXXsqaNWtYtWrViE7aLpeLqqoqDAbDhLPqhePNA8FKEwW2xyqaVyOZdTlTnIkuV7hAlmUOHDhAd3f3WQ1cOp1OlcwtFota5wqGz/upoJCJTqcLu046BV6vl9tuu40jR46wbds20tLSQr2kYSHLMt/61rd4+eWXeffdd5kxY0aolzRm+MwSSiBkWWb//v2sX7+el19+mf3797NixQrKy8tZvXo1qampJzyY/f39VFdXT8jpcfDPOdTU1IzZBHagc19XVxcul2uQr8vZkm9jYyMNDQ1npcsVKijDrn19fRQXFwctqlDqXIqmW1RUlErowSzqKy6R4UwmPp+PO++8k3379rF9+3YyMzNDvaST4q677uK5557jlVdeGTR7kpiYOOEyHqfD54JQAqHoPinkUl1dzfnnn095eTlXXXUVmZmZvPjii3R1dbF69Wry8vImXAFYOdnPmzdvXOYcZFkeJL1vs9kG+bqMpgMv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8slBpym73R6Z4D8F/u///o/777+fN954g4svvhiLxaJ6uqxYsYLc3FzKy8spLy9n4cKFYUku4UomgNp1lJyczEsvvcTVV1/Nnj17iI+Pp7CwkMsuu4zbbrttkEVuOKOvry/oEZVCJmVlZdTX1/PjH/+YhoYGnn76aWpra/nTn/7E9OnTVUOx999/n+uuu46LLrooqOsIN0QilDDDWJymPmvYvXs3Ho+Hc88994TvWa1W1dPlzTffJC0tjTVr1lBeXq56uoQa/f39VFZWhiWZBEIURb7xjW/w6aefsmPHDrKzszlw4AAvv/wycXFxE+KkfeTIEYqLi/ntb3/LnXfeGdTXfvjhh1m/fj1vvPEGqampPPjgg/z2t78lLy+PzMxMnnrqKXJzczl69Ci1tbWsWbMmqO8fjogQSpjhJz/5CW+99Ra7d+8O9VImPBwOB2+99RYbNmxQi8hr1qyhrKyMZcuWhUSmpL+/n4qKCvLz88M6dSRJEt/61rd477332L59O5MnTw7pekY6uDx79mz1762trSxfvpwVK1ao6r7BxD//+U9aWlr40Y9+xMMPP8wf/vAHnnvuOQ4dOsR3v/tdzj33XP70pz8xY8aMoL93uCJCKGGEsTxNfd7hcrnYunUrGzZs4NVXX8VoNLJ69WrWrl3LeeedNy4yJcrg5UQgk+9///u8/fbbvPvuu2Gx1pEOLiu1x7a2NlasWME555zD008/PWaRaV9fH729vaxdu5b77ruP66+/nqamJi6//HIAvvGNb3DPPfeMyXuHIyKEMgYIx9NUBMfh8XgGebrIssyqVatYu3Yty5cvH5OGCIVMwn3wUpIk7r//fjZt2sT27duZPn16qJc0arS2tnLRRRdRXFzMs88+G7RI9GQDiO+99x5XX30127ZtY/78+ezatYvf//73fOtb3xo2LftZRoRQxgDhepqK4ET4fD527typero4nU5WrVpFeXk5F198cVD0qRQymTZtGlOmTAnCqscGkiTxwAMP8Pzzz7N9+3ZmzZoV6iWNGq2traxYsYKpU6fyzDPPDCKTrKysUb/e22+/jdVqpby8/KQ+7wcPHuTmm29WOw3/3//7f1x22WU89thjZ/15JhoihBJijNVpKoLRQxRFPvjgAzZs2MDLL79MX18fV1xxBWVlZVx22WVnZMc6UchElmX++7//m7///e9s27aNuXPnhnpJZ4Snn36a2267bdjvjWark2UZURS58MILsVqtPPjgg6xatQq9Xn8CqYiiyJ/+9CdeeOEFurq6OO+883jqqafO+rNMREQIJYQI9mkqguBBkiQ+/fRTVRm5s7OTyy67jLKyshF7ulgsFqqqqiYEmTz88MM89thjbNu2jQULFoR6SWEDu93OtddeS2dnJ/fddx9r1qzBaDSeoMNltVpxuVxIkkRmZmaolx0yRAglhAjWaSqCsYUkSVRVVameLs3Nzaf1dFHIZPr06SHvkDoVZFnm0Ucf5eGHH2br1q0UFxeHeklhA5/Ph06nw+PxUF5eTltbG/fddx/l5eWDUqGHDx/mv/7rv/jOd77zmZ8zOR0ihBJBBKOA4uny0ksv8fLLL3Po0CEuuugiysvLWbVqFSkpKbzzzjvs2bOH66+/PuzJ5IknnuCXv/wlb7/9NkuXLg31kkIGJdLo7u4eZHetTMSLosjVV19NQ0MDP/zhD7nmmmuIioqisbGRsrIyNBoNVVVVIfwE4YEIoUQQwRlClmXq6urUtNi+ffuYN28etbW1fPe73+X//b//F7b6YrIs8/e//52f/vSnbN68mfPPPz/USwo59u3bx6pVq/j0008HpZwDZVauueYaDh48yP33309paSnr1q1Dp9Px0UcfhWrZYYVIO9HnHI8//jh5eXlERUWxdOlSPv3001AvacJAEAQKCwv56U9/SkVFBf/4xz84cOAA2dnZ/P73v+fKK6/kz3/+M21tbWGVwpRlmX/84x/8+Mc/5pVXXomQyQCsViuyLJ/gbqlEKAAbNmxg3rx5PPjggyxfvhxZliNkEoAIoXyO8cILL/C9732PBx54gMrKShYuXMjll19OV1dXqJc24bBz506++tWv8thjj9HY2MiRI0coLy9n48aNzJ49my984Qs8+uijNDc3h5RcFMn/e++9l5dffpkVK1aEbC3hhpKSEjQaDf/5z39O+F4gqfz73/9m3rx5TJs2LaJoMQSRlNfnGEuXLqW0tFTtl5ckicmTJ/Otb32L++67L8Srm1jYuXMnR48ePaHJQpZl2tra2LhxIxs2bOCDDz5g4cKFlJeXU1ZWRkFBwbimxdavX89dd93Fiy++yMqVK8ftfcMNiuFV4N+9Xi/Lly/nmmuuOam8fGD6K4ITESGUzyk8Hg8xMTGsX79+kGrsLbfcgsVi4ZVXXgnd4j6jkGWZzs5O1dNlx44dFBYWquQya9asMSWXV155hTvuuIPnn3/+cyFUeDocOXKEqqoqli1bRnx8PImJifzP//wPVVVVPP/88yclj6FkFMFxROTrP6cwm82IonhCz3xmZiZ1dXUhWtVnG4IgkJWVxde//nW+9rWv0dPTw6ZNm9i4cSMPPfQQ06dPVz1dCgsLg7ppbd68mTvuuIN//OMfn3sykWUZh8PB1772NSorK0lPT6evr49ly5ZRXV1NdHQ0DoeDmJiYYUklQiYnR+TKRBBBCCAIAqmpqdx+++28/vrrdHZ28sMf/pD9+/ezfPlyioqKeOCBB6iqqhrWjnc02Lp1K7feeit/+9vfuOaaa4L0CSYuBEEgNjaWF198EZPJxPr16/n1r3/N+eefT2FhIYIgcNttt2G1WgfVTiI4PSIpr88pIimv8IXi2a54uqSnp7NmzRrWrl2rFo5HinfffZfrrruOP/3pT9x0001h28YcCgyXunK73WzYsIFHHnmE3NxcnnnmGRISEiJprhEicoU+pzAYDBQXFw/qaJEkif/85z8sW7YshCuLID4+ni996Uu89NJLdHZ28tvf/haTyURZWRlz5szh3nvv5YMPPjjtyfm9997j+uuv55FHHomQyTBQCEI5U0uShNFo5Itf/CLf+ta3MJvNrFy5kr6+vgiZjBCRCOVzjBdeeIFbbrmFJ598kiVLlvDII4/w4osvUldX97nWIwpXOJ1O1dPltddew2g0ctVVV6meLjrd8ZLoxx9/THl5Ob/+9a+56667ImQyQigT86Io8vTTT/PGG2/wt7/9jeTk5FAvbUIgQiifczz22GM8/PDDdHR0sGjRIh599NHPtQTHRIHH42Hbtm2qpwvA6tWrKS8vJz4+nquvvpqf/exn3HPPPWFPJm63m6VLl7Jnzx6qqqpYtGhRSNejkIokSbjdbqKjo0O6nomECKGEGMrlD/eHPoLwhc/nY8eOHap4pclk4ic/+Qk///nPJ8R9dc8993D48GHefPPNsCAUOLmZVgSnRoRQQgi73U5sbGyolxHBZwiiKPLss89y8803T4gN8c033+R73/seGzZsYO7cuWFDKBGcGSKVphDi9ttv54477sDtdqtfU1pEP288/+tf/5rS0lLi4+PJyMigvLycgwcPhnpZEw5arZZbbrllQpBJZ2cnd955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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "\n",
    "# Assuming trainset is a 3D tensor\n",
    "trainset = torch.load(os.path.join(RAW_DATA_PATH, \"gauss_mixture_sphere_dim_3_mix_10/trainset.py\"))\n",
    "x_train = trainset[:256]\n",
    "\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(111, projection='3d')\n",
    "\n",
    "ax.scatter(x_train[:, 0].cpu().numpy(), x_train[:, 1].cpu().numpy(), x_train[:, 2].cpu().numpy())\n",
    "\n",
    "ax.set_xlabel('X Label')\n",
    "ax.set_ylabel('Y Label')\n",
    "ax.set_zlabel('Z Label')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Sanity check on data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: False, used: False\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "\n",
      "  | Name  | Type        | Params\n",
      "--------------------------------------\n",
      "0 | model | MLPDenoiser | 9.7 K \n",
      "--------------------------------------\n",
      "9.7 K     Trainable params\n",
      "0         Non-trainable params\n",
      "9.7 K     Total params\n",
      "0.039     Total estimated model params size (MB)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sanity Checking DataLoader 0: 100%|██████████| 2/2 [00:00<00:00, 236.54it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 1890.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0:  68%|██████▊   | 2118/3125 [00:13<00:06, 159.49it/s, v_num=j52r]   "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: \u001b[33mWARNING\u001b[0m (User provided step: 0 is less than current step: 60. Dropping entry: {'samples_epoch_0': {'_type': 'image-file', 'sha256': 'b4a404be397ac84a787dbbcac2f54994675b278bdbf56ad1ecb4b8a55222bc10', 'size': 13725, 'path': 'media/images/samples_epoch_0_60_b4a404be397ac84a787d.png', 'format': 'png', 'width': 640, 'height': 480}, '_timestamp': 1707177405.480504}).\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:19<00:00, 159.95it/s, v_num=j52r]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "\u001b[A\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 1915.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:21<00:00, 145.23it/s, v_num=j52r]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "`Trainer.fit` stopped: `max_epochs=1` reached.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: 100%|██████████| 3125/3125 [00:21<00:00, 145.14it/s, v_num=j52r]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:00<00:00, 1955.00it/s]\n",
      "100%|██████████| 1000/1000 [00:00<00:00, 2077.42it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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2dkJ+Z2J4uSxSc4eH2OzJ8ZmX04eXyLGZozRyZMn1aVLF6WlNZwZkxIzM2lpaeratWtSfnd2drbjbuAQJ49Ncvb4GJs9MTb7cvL44j22xmZkQkgABgAAtkYwAwAAbI1gJk4yMzM1a9YsZWZmJrsrMefksUnOHh9jsyfGZl9OHp+VxpYSCcAAAMC5mJkBAAC2RjADAABsjWAGAADYGsEMAACwNYKZGKqqqlL//v3lcrlUVlYWcW3Hjh266aablJWVpfz8fM2dO7fOzy9fvly9e/dWVlaW+vbtq9WrVyeo5w37/ve/r27duikrK0t5eXm6//77dfjw4Yg2dhzbxx9/rDFjxqh79+5q3bq1evTooVmzZunMmTMR7ew4Nkl68sknNXjwYLVp00bt27evt82BAwc0fPhwtWnTRjk5OZo6darOnTsX0ebdd9/Vtddeq8zMTPXs2VOLFi2Kf+db4Fe/+pWuuOIKZWVl6YYbbtDmzZuT3aVmee+993THHXeoS5cucrlcWrFiRcR1Y4xmzpypvLw8tW7dWoWFhfr73/8e0eb48eO69957lZ2drfbt22vMmDH64osvEjiKuubMmaNvfvObateunXJycjRixAjt27cvos3p06c1YcIEdezYUW3bttVdd92lysrKiDbNuUeTYf78+brmmmvCxeK8Xq/WrFkTvm7nsZ3vqaeeksvl0qRJk8KvWXZsBjHzH//xH+Z73/uekWS2b98efj0QCJjc3Fxz7733mvLycvPqq6+a1q1bm9/85jfhNn/5y19Menq6mTt3rtm9e7d5/PHHTatWrczOnTuTMJKvPP/888bn85mPP/7Y/OUvfzFer9d4vd7wdbuObc2aNWb06NFm7dq1Zv/+/WblypUmJyfHTJkyJdzGrmMzxpiZM2ea559/3kyePNm43e4618+dO2f69OljCgsLzfbt283q1atNp06dTHFxcbjNP/7xD9OmTRszefJks3v3bjNv3jyTnp5uSkpKEjiSpi1btsxkZGSY3/3ud2bXrl1m7Nixpn379qaysjLZXWvS6tWrzYwZM8yf/vQnI8m88cYbEdefeuop43a7zYoVK8xf//pX8/3vf990797dfPnll+E2w4YNM/369TMbN240//u//2t69uxpRo0aleCRRCoqKjIvv/yyKS8vN2VlZea2224z3bp1M1988UW4zbhx40x+fr5Zt26d2bJlixk0aJAZPHhw+Hpz7tFk+fOf/2zeeust87e//c3s27fP/Nd//Zdp1aqVKS8vN8bYe2whmzdvNldccYW55pprzKOPPhp+3apjI5iJkdWrV5vevXubXbt21Qlmfv3rX5vLLrvMVFVVhV+bNm2a6dWrV/j5v/7rv5rhw4dHvOcNN9xgfvzjH8e979FYuXKlcblc5syZM8YYZ41t7ty5pnv37uHnThjbyy+/XG8ws3r1apOWlmb8fn/4tfnz55vs7OzweB977DHzjW98I+LnRo4caYqKiuLa52hdf/31ZsKECeHn1dXVpkuXLmbOnDlJ7FX0LgxmampqjMfjMc8880z4tRMnTpjMzEzz6quvGmOM2b17t5FkPvzww3CbNWvWGJfLZQ4dOpSwvjfl6NGjRpLZsGGDMaZ2HK1atTLLly8Pt9mzZ4+RZHw+nzGmefeolVx22WXmt7/9rSPGdvLkSXPVVVeZ0tJS8+1vfzsczFh5bCwzxUBlZaXGjh2r3//+92rTpk2d6z6fTzfffLMyMjLCrxUVFWnfvn36/PPPw20KCwsjfq6oqEg+ny++nY/C8ePH9corr2jw4MFq1aqVJOeMTZICgYA6dOgQfu6ksV3I5/Opb9++ys3NDb9WVFSkYDCoXbt2hdtYfWxnzpzR1q1bI/qZlpamwsJCS/WzJSoqKuT3+yPG5na7dcMNN4TH5vP51L59e1133XXhNoWFhUpLS9OmTZsS3ueGBAIBSQr/97V161adPXs2Ymy9e/dWt27dIsbW1D1qBdXV1Vq2bJlOnTolr9friLFNmDBBw4cPr/Pfv5XHRjBzkYwxGj16tMaNGxfxP5Tz+f3+iL9YSeHnfr+/0Tah68k0bdo0XXrpperYsaMOHDiglStXhq/ZfWwhH330kebNm6cf//jH4decMrb6XMzYgsGgvvzyy8R0tAn//Oc/VV1dbcu/g6aE+t/Y2Px+v3JyciKuX3LJJerQoYNlxl9TU6NJkybpW9/6lvr06SOptt8ZGRl18rkuHFtT92gy7dy5U23btlVmZqbGjRunN954QwUFBbYf27Jly7Rt2zbNmTOnzjUrj41gpgHTp0+Xy+Vq9LF3717NmzdPJ0+eVHFxcbK73GzNHVvI1KlTtX37dr399ttKT0/XAw88IGPRwtHRjk2SDh06pGHDhumHP/yhxo4dm6SeN60lYwOSbcKECSovL9eyZcuS3ZWY6tWrl8rKyrRp0yaNHz9eDz74oHbv3p3sbl2UgwcP6tFHH9Urr7yirKysZHcnKpckuwNWNWXKFI0ePbrRNldeeaXWr18vn89X52yK6667Tvfee68WL14sj8dTJ9s79Nzj8YT/WV+b0PVYau7YQjp16qROnTrp61//uq6++mrl5+dr48aN8nq9th/b4cOHNWTIEA0ePFgLFy6MaGf3sTXG4/HU2fHT3LFlZ2erdevWzex1fHXq1Enp6ekJ+ztIpFD/KysrlZeXF369srJS/fv3D7c5evRoxM+dO3dOx48ft8T4J06cqFWrVum9995T165dw697PB6dOXNGJ06ciPiWf/7fW3Pu0WTKyMhQz549JUkDBw7Uhx9+qBdeeEEjR4607di2bt2qo0eP6tprrw2/Vl1drffee08vvvii1q5da92xxS0bJ0V88sknZufOneHH2rVrjSTz+uuvm4MHDxpjvkokDSXNGmNMcXFxnUTS22+/PeK9vV6vZRJJQz755BMjybzzzjvGGHuP7dNPPzVXXXWVueeee8y5c+fqXLfz2EKaSgA+f8fPb37zG5OdnW1Onz5tjKlNAO7Tp0/Ez40aNcqSCcATJ04MP6+urjaXX365YxKAn3322fBrgUCg3gTgLVu2hNusXbs26QnANTU1ZsKECaZLly7mb3/7W53roUTS119/Pfza3r17600kbewetZIhQ4aYBx980NZjCwaDEZ9nO3fuNNddd5257777zM6dOy09NoKZGKuoqKizm+nEiRMmNzfX3H///aa8vNwsW7bMtGnTps4W30suucQ8++yzZs+ePWbWrFlJ3+K7ceNGM2/ePLN9+3bz8ccfm3Xr1pnBgwebHj16hG9Ku47t008/NT179jS33HKL+fTTT82RI0fCjxC7js2Y2qBz+/btZvbs2aZt27Zm+/btZvv27ebkyZPGmK+2Tw4dOtSUlZWZkpIS07lz53q3Zk+dOtXs2bPH/OpXv7Ls1uzMzEyzaNEis3v3bvPII4+Y9u3bR+ymsKqTJ0+G/24kmeeff95s377dfPLJJ8aY2q3Z7du3NytXrjQ7duwwd955Z71bswcMGGA2bdpk3n//fXPVVVclfWv2+PHjjdvtNu+++27Ef1v/93//F24zbtw4061bN7N+/XqzZcuWOmUfmnOPJsv06dPNhg0bTEVFhdmxY4eZPn26cblc5u233zbG2HtsFzp/N5Mx1h0bwUyM1RfMGGPMX//6V3PjjTeazMxMc/nll5unnnqqzs/+4Q9/MF//+tdNRkaG+cY3vmHeeuutBPW6fjt27DBDhgwxHTp0MJmZmeaKK64w48aNM59++mlEOzuO7eWXXzaS6n2cz45jM8aYBx98sN6xhWbUjDHm448/Nt/73vdM69atTadOncyUKVPM2bNnI97nnXfeMf379zcZGRnmyiuvNC+//HJiB9JM8+bNM926dTMZGRnm+uuvNxs3bkx2l5rlnXfeqffv6cEHHzTG1M5w/Pd//7fJzc01mZmZ5pZbbjH79u2LeI9jx46ZUaNGmbZt25rs7Gzz0EMPhYPWZGnov63z758vv/zS/Pu//7u57LLLTJs2bcy//Mu/RHyZMKZ592gyPPzww+ZrX/uaycjIMJ07dza33HJLOJAxxt5ju9CFwYxVx+YyxqKZnAAAAM3AbiYAAGBrBDMAAMDWCGYAAICtEcwAAABbI5gBAAC2RjADAABsjWAGAADYGsEMAACwNYIZAABgawQzAADA1ghmAACArRHMAAAAW/v/ABDfHyfVVo/4AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[34m\u001b[1mwandb\u001b[0m: \u001b[33mWARNING\u001b[0m (User provided step: 0 is less than current step: 60. Dropping entry: {'samples_epoch_0': {'_type': 'image-file', 'sha256': '569a9e9c086f904d02277dee3c6cffa87f56bbb01b8727215a79dd20e462f4c7', 'size': 16869, 'path': 'media/images/samples_epoch_0_60_569a9e9c086f904d0227.png', 'format': 'png', 'width': 640, 'height': 480}, '_timestamp': 1707177426.9984698}).\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning.loggers.wandb import WandbLogger\n",
    "import torch\n",
    "from src.diffusion.SDE import VPSDE, GenPinnedBrownSDE\n",
    "from src.constants import PROJECT_PATH, RAW_DATA_PATH\n",
    "import os\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "from src.models.model_toy_2D import ToyDiffusion\n",
    "from src.denoisers.MLP import MLPDenoiser\n",
    "import matplotlib.pyplot as plt\n",
    "from hydra import initialize, compose\n",
    "from pytorch_lightning import Trainer, seed_everything\n",
    "from src.data.datamodules import get_complicated_dataset\n",
    "import wandb\n",
    "import argparse\n",
    "\n",
    "\n",
    "with initialize(version_base=None, config_path=f\"../configs/\"):  \n",
    "    cfg = compose(config_name='config_toy_2D.yaml')\n",
    "\n",
    "parser = argparse.ArgumentParser(description=\"Your script description.\")\n",
    "parser.add_argument(\"--dim\", type=int)\n",
    "parser.add_argument(\"--mix\", type=int)\n",
    "parser.add_argument(\"--hid_dim\", type=int)\n",
    "parser.add_argument(\"--std\", type=str)\n",
    "\n",
    "args = parser.parse_args()\n",
    "\n",
    "wandb_logger = WandbLogger(project='tryout')\n",
    "dim = args.dim\n",
    "mix = args.mix\n",
    "\n",
    "if args.mix==10:\n",
    "    sphere = \"sphere_\"\n",
    "else:\n",
    "    sphere=\"\"\n",
    "cfg.model.data_dim= dim\n",
    "cfg.model.hid_dim= 32\n",
    "if args.std == \"vp\":\n",
    "    sde =  VPSDE()\n",
    "else:\n",
    "    sde = GenPinnedBrownSDE()\n",
    "denoiser = MLPDenoiser(in_dim=dim+1, hid_dim=cfg.model.hid_dim, num_hid_layers=cfg.model.num_hid_layers, dropout=cfg.model.dropout, out_dim=dim)\n",
    "diffuser = ToyDiffusion(cfg, denoiser, sde)\n",
    "diffuser.to('cpu')\n",
    "\n",
    "\n",
    "# Instantiate Trainer\n",
    "trainer = Trainer(max_epochs=1, logger=wandb_logger)\n",
    "\n",
    "# Train model\n",
    "dataset = get_complicated_dataset(sphere=sphere, dim=dim, mix=mix)\n",
    "trainer.fit(diffuser, dataset)\n",
    "\n",
    "xs = []\n",
    "for i in range(2):\n",
    "    xs.append(diffuser.sample(eta=1.))\n",
    "\n",
    "x_new = torch.cat(xs, dim=0)\n",
    "\n",
    "           \n",
    "            \n",
    "wandb_logger.experiment.log({'x_new': wandb.Table(data=x_new.numpy(), columns=[f'col_{i}' for i in range(x_new.numpy().shape[1])])})\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "temp_ammo",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
