{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "e6f58cd6",
   "metadata": {},
   "source": [
    "### Loading the approximate energy function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce192b8e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import tqdm\n",
    "from mol_utils import PotentialModel, mod_pi, extended_mod\n",
    "from mol_utils import MLP, alpha_sigma\n",
    "\n",
    "# Model approximating the energy function\n",
    "state_dict = torch.load('potential_model.pt')\n",
    "pot_model = PotentialModel([64, 64])\n",
    "pot_model.load_state_dict(state_dict)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "408c8c36",
   "metadata": {},
   "source": [
    "### Generating training data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "78c7787c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/zv/qtb0nk453wd95ll0x83096j40000gp/T/ipykernel_34400/864036279.py:20: UserWarning: Creating a tensor from a list of numpy.ndarrays is extremely slow. Please consider converting the list to a single numpy.ndarray with numpy.array() before converting to a tensor. (Triggered internally at /Users/runner/work/pytorch/pytorch/pytorch/torch/csrc/utils/tensor_new.cpp:264.)\n",
      "  inp = torch.tensor([x, y]).view(2, -1).T\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:14<00:00, 68.99it/s]\n"
     ]
    }
   ],
   "source": [
    "def langevin_dynamics(inp, dt, n_steps):\n",
    "    \"\"\"\n",
    "    Since the energy function is defined on a torus, we `extend` the domain outside (-pi, pi) to \n",
    "    make the training of diffusion model easier. \n",
    "    \"\"\"\n",
    "    x = inp.float()\n",
    "    for i in tqdm.tqdm(range(n_steps)):\n",
    "        in_bounds_x = mod_pi(x)\n",
    "        in_bounds_x = in_bounds_x.detach().clone().requires_grad_(True)\n",
    "        pot_pred = pot_model(in_bounds_x)\n",
    "        drift = -torch.autograd.grad(pot_pred.sum(), in_bounds_x)[0]\n",
    "        x = x + 0.5 * dt * drift + torch.sqrt(dt) * torch.randn_like(x)\n",
    "        x = extended_mod(x).detach()\n",
    "    return x\n",
    "\n",
    "_delta = 0.05\n",
    "xs = np.arange(-np.pi, np.pi + _delta, _delta)\n",
    "ys = np.arange(-np.pi, np.pi + _delta, _delta)\n",
    "x, y = np.meshgrid(xs, ys)\n",
    "inp = torch.tensor([x, y]).view(2, -1).T\n",
    "\n",
    "traj = langevin_dynamics(inp, torch.tensor(0.001), 1000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "56aa7e88",
   "metadata": {},
   "outputs": [],
   "source": [
    "from mol_utils import visualize_energy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6962de70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7ff1a0b5e310>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "traj_numpy = mod_pi(traj).numpy()\n",
    "fig, ax = plt.subplots(figsize=(5, 4))\n",
    "visualize_energy(fig, ax, pot_model, alpha=0.2)\n",
    "ax.scatter(traj_numpy[:, 0], traj_numpy[:, 1], color='C3', s=1, alpha=0.4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "216ce519",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:14<00:00, 70.84it/s]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:14<00:00, 69.47it/s]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:14<00:00, 71.33it/s]\n",
      "100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [00:14<00:00, 71.05it/s]\n"
     ]
    }
   ],
   "source": [
    "full_dataset = traj.detach()\n",
    "for i in range(4):\n",
    "    traj = langevin_dynamics(traj, torch.tensor(0.001), 1000)\n",
    "    full_dataset = torch.cat([full_dataset, traj.detach()])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f8cec2c",
   "metadata": {},
   "source": [
    "### Training diffusion model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ddbfb1a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Implementation of adaptive noise schedule as introduced in Kingma and Gao\n",
    "# \"Understanding Diffusion Objectives as the ELBO with Simple Data Augmentation\" (NeurIPS 2023)\n",
    "class ImportanceSampler(nn.Module):\n",
    "    def __init__(self, l_min, l_max, n_bins, p=None, eta=0.999):\n",
    "        super().__init__()\n",
    "        self.n_bins = n_bins\n",
    "        self.l_min = l_min\n",
    "        self.l_max = l_max\n",
    "        self.bin_width = (l_max - l_min) / n_bins\n",
    "        self.eta = eta\n",
    "        \n",
    "        # p: shape [n_bins]\n",
    "        if p is None:\n",
    "            p = torch.ones(n_bins, dtype=torch.float32)\n",
    "        else:\n",
    "            p = p.clone().detach().float()\n",
    "        \n",
    "        # Register p and bin_edges as buffers so they’re moved automatically \n",
    "        # to the correct device (CPU/GPU) and saved with state dict,\n",
    "        # but are not considered trainable parameters.\n",
    "        self.register_buffer(\"p\", p)\n",
    "        bin_edges = torch.linspace(l_min, l_max, n_bins + 1, dtype=torch.float32)\n",
    "        self.register_buffer(\"bin_edges\", bin_edges)\n",
    "\n",
    "    def update(self, l, v):\n",
    "        \"\"\"\n",
    "        Updates self.p at the bin index corresponding to `l`.\n",
    "        \n",
    "        l: scalar or 1D tensor\n",
    "        v: scalar or 1D tensor (same shape as l)\n",
    "        \"\"\"\n",
    "        # Convert to float (avoid potential double -> long issues).\n",
    "        l = l.float()\n",
    "        v = v.float()\n",
    "\n",
    "        # Compute bin indices\n",
    "        bin_indices = torch.floor((l - self.l_min) / self.bin_width).long()\n",
    "\n",
    "        # Make sure indices are in range [0, n_bins - 1]\n",
    "        bin_indices = torch.clamp(bin_indices, 0, self.n_bins - 1)\n",
    "\n",
    "        # In-place update\n",
    "        with torch.no_grad():\n",
    "            self.p[bin_indices] = self.p[bin_indices] * self.eta + (1 - self.eta) * v\n",
    "\n",
    "    def prob(self, l):\n",
    "        \"\"\"\n",
    "        Returns the probability density at l according to the current p distribution.\n",
    "        \n",
    "        l: scalar or 1D tensor\n",
    "        \"\"\"\n",
    "        l = l.float()\n",
    "        bin_indices = torch.floor((l - self.l_min) / self.bin_width).long()\n",
    "        bin_indices = torch.clamp(bin_indices, 0, self.n_bins - 1)\n",
    "        return self.p[bin_indices] / self.p.sum() / self.bin_width\n",
    "\n",
    "    def transform(self, l):\n",
    "        \"\"\"\n",
    "        Applies the \"cumulative\" transform to map l in [l_min, l_max] to new values\n",
    "        according to the histogram distribution in p.\n",
    "        \n",
    "        l: scalar or 1D tensor\n",
    "        \"\"\"\n",
    "        l = l.float()\n",
    "        cumsums = self._compute_sums()  # shape [n_bins+1]\n",
    "        normalized_l = (l - self.l_min) / (self.l_max - self.l_min)\n",
    "        return self._interp(normalized_l, cumsums, self.bin_edges)\n",
    "\n",
    "    def prob_and_transform(self, l):\n",
    "        \"\"\"\n",
    "        Returns (prob, transformed_value) for input l.\n",
    "        \"\"\"\n",
    "        l = l.float()\n",
    "        cumsums = self._compute_sums()\n",
    "        normalized_l = (l - self.l_min) / (self.l_max - self.l_min)\n",
    "        transformed = self._interp(normalized_l, cumsums, self.bin_edges)\n",
    "        \n",
    "        # Determine bin indices of the transformed value\n",
    "        bin_indices = torch.floor((transformed - self.l_min) / self.bin_width).long()\n",
    "        bin_indices = torch.clamp(bin_indices, 0, self.n_bins - 1)\n",
    "\n",
    "        probs = self.p[bin_indices] / self.p.sum() / self.bin_width\n",
    "        return probs, transformed\n",
    "\n",
    "    def _compute_sums(self):\n",
    "        \"\"\"\n",
    "        Computes normalized cumulative sum of p, with a leading 0.0.\n",
    "        Result shape is [n_bins+1].\n",
    "        \"\"\"\n",
    "        total_mass = self.p.sum()\n",
    "        cumsums = torch.cumsum(self.p, dim=0) / total_mass\n",
    "        cumsums = torch.cat([torch.tensor([0.0], device=cumsums.device, dtype=cumsums.dtype), cumsums], dim=0)\n",
    "        return cumsums\n",
    "\n",
    "    def _interp(self, x, xp, fp):\n",
    "        \"\"\"\n",
    "        PyTorch equivalent of numpy/jax `interp(x, xp, fp)`.\n",
    "        * x can be scalar or 1D\n",
    "        * xp and fp must be 1D and sorted, with same length\n",
    "        \"\"\"\n",
    "        # x < xp[0] => clamp to xp[0], x > xp[-1] => clamp to xp[-1]\n",
    "        # We'll do a piecewise-linear interpolation using searchsorted.\n",
    "        # 'right=True' to match numpy.interp’s default behavior.\n",
    "        indices = torch.searchsorted(xp, x, right=True)\n",
    "        \n",
    "        # For any x < xp[0], indices=0 => clamp to 1\n",
    "        # For any x > xp[-1], indices=len(xp) => clamp to len(xp)-1\n",
    "        indices = torch.clamp(indices, 1, xp.shape[0] - 1)\n",
    "\n",
    "        x0 = xp[indices - 1]\n",
    "        x1 = xp[indices]\n",
    "        y0 = fp[indices - 1]\n",
    "        y1 = fp[indices]\n",
    "\n",
    "        slope = (y1 - y0) / (x1 - x0)\n",
    "        return y0 + slope * (x - x0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7cea4400",
   "metadata": {},
   "outputs": [],
   "source": [
    "LAMBDA_MIN, LAMBDA_MAX = -12, 12\n",
    "def sample_l(batch_size, sampler):\n",
    "    l = LAMBDA_MIN + (LAMBDA_MAX - LAMBDA_MIN) / batch_size * torch.rand(size=(batch_size,))\n",
    "    l = l + ((LAMBDA_MAX - LAMBDA_MIN) / batch_size) * torch.arange(batch_size)\n",
    "    prob_l, reweighted_l = sampler.prob_and_transform(l)\n",
    "    return prob_l, reweighted_l"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "62ecc00f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def update_importance_sampler(model, sampler, batch_size):\n",
    "    with torch.no_grad():\n",
    "        ex_indices = torch.randint(low=0, high=full_dataset.shape[0], size=(batch_size,))\n",
    "        batch = mod_pi(full_dataset[ex_indices].detach())\n",
    "        l = LAMBDA_MIN + (LAMBDA_MAX - LAMBDA_MIN) / batch_size * torch.rand(size=(batch_size,))\n",
    "        l = l + ((LAMBDA_MAX - LAMBDA_MIN) / batch_size) * torch.arange(batch_size)\n",
    "        alpha, sigma = alpha_sigma(l)\n",
    "        noisy_batch = alpha.unsqueeze(1) * batch + sigma.unsqueeze(1) * torch.randn_like(batch)    \n",
    "        preds = model(noisy_batch, l)\n",
    "        weight = torch.sigmoid(l + 2) ** 0.5\n",
    "        all_losses = ((preds - batch) ** 2).sum(dim=1) * weight\n",
    "        sampler.update(l, all_losses)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "855a217d",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampler = ImportanceSampler(LAMBDA_MIN, LAMBDA_MAX, 100, p=None, eta=0.99)\n",
    "\n",
    "model = MLP(\n",
    "    hidden_size=128,\n",
    "    hidden_layers=3,\n",
    "    emb_size=128,\n",
    "    time_emb=\"sinusoidal\",\n",
    "    input_emb=\"sinusoidal\"\n",
    ")\n",
    "losses = []\n",
    "opt = torch.optim.AdamW(model.parameters(), lr=1e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f7938c77",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|                                                                                                                                     | 0/4000 [00:00<?, ?it/s]/Users/karczer1/opt/miniconda3/envs/jax/lib/python3.9/site-packages/numpy/core/fromnumeric.py:3464: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/Users/karczer1/opt/miniconda3/envs/jax/lib/python3.9/site-packages/numpy/core/_methods.py:192: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  ret = ret.dtype.type(ret / rcount)\n",
      "100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████| 4000/4000 [01:17<00:00, 51.73it/s, loss=0.3971]\n"
     ]
    }
   ],
   "source": [
    "import tqdm\n",
    "n_steps = 4000\n",
    "batch_size = 1024\n",
    "import time\n",
    "pbar = tqdm.tqdm(range(n_steps)) \n",
    "for step in pbar:\n",
    "    # sample training example\n",
    "    ex_indices = torch.randint(low=0, high=full_dataset.shape[0], size=(batch_size,))\n",
    "    batch = mod_pi(full_dataset[ex_indices].detach())\n",
    "    # reweight l\n",
    "    prob_l, reweighted_l = sample_l(batch_size, sampler)\n",
    "    \n",
    "    alpha, sigma = alpha_sigma(reweighted_l)\n",
    "    noisy_batch = alpha.unsqueeze(1) * batch + sigma.unsqueeze(1) * torch.randn_like(batch)    \n",
    "    preds = model(noisy_batch, reweighted_l)\n",
    "    weight = torch.sigmoid(reweighted_l + 2) ** 0.5 # Add weight as in Kingma et al. \"Understanding Diffusion Objectives as the ELBOwith Simple Data Augmentation\"\n",
    "    all_losses = ((preds - batch) ** 2).sum(dim=1) * weight\n",
    "    uniform_prob = 1 / (LAMBDA_MAX - LAMBDA_MIN)\n",
    "    importance_weights = uniform_prob / prob_l\n",
    "    loss = (all_losses * importance_weights).mean()\n",
    "    opt.zero_grad()\n",
    "    loss.backward()\n",
    "    opt.step()\n",
    "    avg_loss = np.mean(losses[-200:])\n",
    "    pbar.set_postfix_str(f\"loss={avg_loss:.4f}\")\n",
    "    losses.append(loss.item())\n",
    "    if step > 100 and (step % 10 == 0): # Update importance sampler\n",
    "        update_importance_sampler(model, sampler, batch_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "45f85c31",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.save(model.state_dict(), 'diffusion_model.pt')"
   ]
  }
 ],
 "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
