{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "715ecee1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import math\n",
    "\n",
    "import torch\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.autograd as autograd\n",
    "\n",
    "from torch import distributions as D\n",
    "\n",
    "def set_pub():\n",
    "    plt.rcParams.update({\n",
    "        #\"font.weight\": \"bold\",  # bold fonts\n",
    "        \"xtick.labelsize\": 13,\n",
    "        \"ytick.labelsize\": 13,\n",
    "        \"axes.labelsize\": 13,\n",
    "        #\"tick.labelsize\": 15,   # large tick labels\n",
    "        #\"lines.linewidth\": 1,   # thick lines\n",
    "        #\"lines.color\": \"k\",     # black lines\n",
    "        \"grid.color\": \"0.5\",    # gray gridlines\n",
    "        \"grid.linestyle\": \"-\",  # solid gridlines\n",
    "        \"grid.linewidth\": 0.5,  # thin gridlines\n",
    "        \"savefig.dpi\": 300,     # higher resolution output.\n",
    "    })"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "369b27e6",
   "metadata": {},
   "source": [
    "### Definition of the Energy Discrepancy Loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5ab4a192",
   "metadata": {},
   "outputs": [],
   "source": [
    "def energy_discrepancy(energy_net, samples, m_particles=4, t_noise=1.0, w_stable=1.0, seed = None):\n",
    "    device = samples.device\n",
    "    \n",
    "    if seed != None:\n",
    "        torch.manual_seed(seed)\n",
    "\n",
    "    browniani = torch.randn_like(samples).to(device) * np.sqrt(t_noise)\n",
    "    brownianij = torch.randn(samples.size(0), m_particles, *samples.shape[1:]).to(device) * np.sqrt(t_noise)\n",
    "\n",
    "    pert_data = samples.unsqueeze(1) + browniani.unsqueeze(1) + brownianij\n",
    "\n",
    "    pos_energy = energy_net(samples)\n",
    "    neg_energy = energy_net(pert_data.view(-1, *samples.shape[1:])).view(samples.size(0), -1)\n",
    "    val = pos_energy - neg_energy\n",
    "    if w_stable != 0:\n",
    "        val = torch.cat([val, np.log(w_stable) * torch.ones_like(val[:, :1])], dim=-1)\n",
    "\n",
    "    loss = val.logsumexp(dim=-1).mean()\n",
    "    if t<1.:\n",
    "        loss = loss/t\n",
    "    return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b46b28f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SmallMLP(nn.Module):\n",
    "    def __init__(self, n_dims, n_hid=8, layer=nn.Linear):\n",
    "        super(SmallMLP, self).__init__()\n",
    "        self._built = False\n",
    "        self.net = nn.Sequential(\n",
    "            layer(n_dims, n_hid),\n",
    "            nn.SiLU(),\n",
    "            layer(n_hid, n_hid),\n",
    "            nn.SiLU(),\n",
    "            layer(n_hid, 1)\n",
    "        )\n",
    "        self.normalized = False\n",
    "\n",
    "    def forward(self, u):\n",
    "        out = self.net(u)\n",
    "        return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "baf89d03",
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "def train(data, model = None, n=4096, m=4, t=1., w=1., n_epochs=20, batch_size=64):    \n",
    "        \n",
    "    opt = torch.optim.Adam(model.parameters(), lr=0.01)\n",
    "    \n",
    "    dataloader = torch.utils.data.DataLoader(data, batch_size=batch_size,\n",
    "                                          shuffle=True)\n",
    "    \n",
    "    loss_history = [0.]\n",
    "    for i in tqdm(range(n_epochs)):\n",
    "        batch_loss = 0.\n",
    "        for batch in dataloader:\n",
    "            opt.zero_grad()\n",
    "            loss_val = energy_discrepancy(energy_net = model, samples = data, m_particles=m, t_noise=t, w_stable=w)\n",
    "            loss_val.backward()\n",
    "            opt.step()\n",
    "            batch_loss += loss_val.item()\n",
    "            \n",
    "        batch_loss = batch_loss/len(dataloader)\n",
    "        loss_history.append(batch_loss)\n",
    "    \n",
    "    return model, loss_history"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "5d646866",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mse_log_prob(distribution, energy_net, device=None):\n",
    "    samples = distribution.sample((10000,))\n",
    "\n",
    "    if device is not None:\n",
    "        samples = samples.to(device)\n",
    "\n",
    "    log_ground_truth = -distribution.log_prob(samples)\n",
    "    \n",
    "\n",
    "    log_prob = -energy_net(samples.unsqueeze(-1))\n",
    "    print(log_prob.shape)\n",
    "    logZ = torch.logsumexp(log_prob.squeeze(-1)-log_ground_truth, dim=(0)) - np.log(10000)\n",
    "    print(logZ.shape)\n",
    "    log_prob_ebm = log_prob - logZ\n",
    "    print(log_prob_ebm.shape)\n",
    "\n",
    "    return torch.mean((log_prob_ebm - log_ground_truth) ** 2).cpu().item(), logZ.cpu().item()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c1c212d7",
   "metadata": {},
   "source": [
    "### Energy Estimation for various choices of w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "67d7da0e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████| 50/50 [00:08<00:00,  6.04it/s]\n",
      "100%|███████████████████████████████████████████| 50/50 [00:08<00:00,  5.90it/s]\n",
      "100%|███████████████████████████████████████████| 50/50 [00:08<00:00,  5.98it/s]\n",
      "100%|███████████████████████████████████████████| 50/50 [00:08<00:00,  5.89it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_pub()\n",
    "m = 4\n",
    "n = 4096\n",
    "t = 1.\n",
    "ws = [0., 0.1, 1., 4.]\n",
    "x = torch.arange(-3, 3, 0.1)\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "data = torch.randn(n, 1)\n",
    "y_true = x**2/2\n",
    "plt.plot(x, y_true, '--', label = f'ground_truth', color = 'grey')\n",
    "\n",
    "for w in ws:\n",
    "    model = SmallMLP(n_dims = 1, n_hid = 2)\n",
    "    model, loss_history = train(data, model = model, n=n, m=m, t=t, w=w, n_epochs=50, batch_size=64)\n",
    "    minimum = model(x.unsqueeze(1)).min()\n",
    "    y = model(x.unsqueeze(1)).detach()-minimum.detach()\n",
    "    plt.plot(x, y, label = f'w = {w}')\n",
    "    \n",
    "plt.ylim(-0.1, 3.)\n",
    "plt.xlabel(\"x\")\n",
    "plt.ylabel(\"estimated energy\")\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "plt.grid(linestyle='--', linewidth=0.5, alpha=0.5)\n",
    "plt.grid(True)\n",
    "plt.legend(frameon = False)\n",
    "plt.savefig('Images/Tuningwform=4.pdf', dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0bf6b333",
   "metadata": {},
   "source": [
    "### Comparison of Nearsightedness of Energy Discrepancy, Maximum Likelihood Estimation, and Score Matching"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "504baea5",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Mixture_model():\n",
    "    def __init__(self, distribution_a, distribution_b, weights = None):\n",
    "        self.weights = weights\n",
    "        self.distribution_a = distribution_a\n",
    "        self.distribution_b = distribution_b\n",
    "        \n",
    "    def set_parameter(self, value):\n",
    "        self.weights = value\n",
    "        \n",
    "    def sample(self, n_samples):\n",
    "        alpha = self.weights\n",
    "        b = torch.distributions.Bernoulli(torch.tensor([alpha]))\n",
    "\n",
    "        data = torch.zeros(n_samples, 1)\n",
    "\n",
    "        index = b.sample((n_samples,))\n",
    "\n",
    "        for i in range(n_samples):\n",
    "            if index[i]==1:\n",
    "                data[i, :]=self.distribution_a.sample()\n",
    "            else:\n",
    "                data[i, :]=self.distribution_b.sample()\n",
    "        return data\n",
    "\n",
    "    def energy(self, x):\n",
    "        alpha = self.weights\n",
    "\n",
    "        log_prob_a = distribution_a.log_prob(x) + np.log(alpha)\n",
    "        log_prob_b = distribution_b.log_prob(x) + np.log(1-alpha)\n",
    "\n",
    "        log_probs = torch.cat((log_prob_a.unsqueeze(1), log_prob_b.unsqueeze(1)), 1)\n",
    "\n",
    "        energy = -torch.logsumexp(log_probs, 1)\n",
    "        return energy\n",
    "    \n",
    "    def negative_loglikelihood(self, data):\n",
    "        return self.energy(data).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8678093f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x129bba190>]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "rho = 0.2\n",
    "distribution_a = D.Normal(loc = torch.tensor([-5.]), scale = torch.tensor([1.0]))\n",
    "distribution_b = D.Normal(loc = torch.tensor([5.]), scale = torch.tensor([1.0]))\n",
    "\n",
    "gauss_mixture = Mixture_model(distribution_a, distribution_b, rho)\n",
    "\n",
    "x = torch.arange(-10., 10., 0.1)\n",
    "plt.plot(x, np.exp(-gauss_mixture.energy(x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "c15a124a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy.optimize import minimize_scalar\n",
    "\n",
    "def energy_discrepancy_opt_fn(rho, *args):\n",
    "    data, seed, m, t, w = args\n",
    "    gauss_mixture.set_parameter(rho)\n",
    "    val = energy_discrepancy(energy_net = gauss_mixture.energy, samples = data, m_particles=m, t_noise=t, w_stable=w, seed = seed)\n",
    "    return val\n",
    "\n",
    "def mle_opt_fn(rho, *args):\n",
    "    data, = args\n",
    "    gauss_mixture.set_parameter(rho)\n",
    "    return gauss_mixture.negative_loglikelihood(data)\n",
    "\n",
    "def score(energy, samples):\n",
    "    with torch.enable_grad():\n",
    "        samples = samples.detach()\n",
    "        samples.requires_grad_(True)\n",
    "        log_probs = energy(samples).sum()\n",
    "        return autograd.grad(log_probs, samples)[0]\n",
    "\n",
    "def fish_divergence(rho, *args):\n",
    "    gauss_mixture.set_parameter(0.2)\n",
    "    energy_truth = gauss_mixture.energy\n",
    "    gauss_mixture.set_parameter(rho)\n",
    "    #samples = selsample(num_samples)\n",
    "    return 0.5 * ((score(gauss_mixture.energy, data) - score(energy_truth, data))**2).mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "43c47e08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "set_pub()\n",
    "\n",
    "gauss_mixture.set_parameter(0.2)\n",
    "data = gauss_mixture.sample(4096)\n",
    "\n",
    "rhos = np.arange(0.01, 0.99, 0.01)\n",
    "\n",
    "seed = np.random.randint(100000)\n",
    "\n",
    "ts = [1, 2, 4, 8, 32]\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(rhos, [fish_divergence(rho, data) for rho in rhos], label = 'SM', linestyle = '--')\n",
    "for t in ts[1:]:\n",
    "    losses = []\n",
    "    for rho in rhos:\n",
    "        m = 4\n",
    "        w = 1.\n",
    "        gauss_mixture.set_parameter(rho)\n",
    "        val = energy_discrepancy(energy_net = gauss_mixture.energy, samples = data, m_particles=m, t_noise=t, w_stable=w, seed = seed)\n",
    "        losses.append(val)\n",
    "\n",
    "    losses = np.array(losses)\n",
    "\n",
    "    min_val = min(losses)\n",
    "    ax.plot(rhos, losses-min_val, label = f'ED_t={t}')\n",
    "    \n",
    "losses = []\n",
    "for rho in rhos:\n",
    "    gauss_mixture.set_parameter(rho)\n",
    "    val = gauss_mixture.negative_loglikelihood(data)\n",
    "    losses.append(val)\n",
    "\n",
    "losses = np.array(losses)\n",
    "\n",
    "min_val = min(losses)\n",
    "ax.plot(rhos, losses-min_val, label = f'MLE', linestyle = '--')\n",
    "    \n",
    "#ax.plot(0.2, 0.,  marker='*')\n",
    "plt.legend(fontsize=13, loc = 'upper right', frameon = True, edgecolor = 'white')\n",
    "plt.ylim(-0.01, 0.1)\n",
    "plt.xlabel(\"mixture weight\")\n",
    "plt.ylabel(\"loss (SM / ED/ CE)\")\n",
    "#ax.annotate('rho', xy=(0.2, 0.))\n",
    "ax.axvline(0.2, color = 'grey', linestyle = '--')\n",
    "plt.grid(linestyle='--', linewidth=0.5, alpha=0.5)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "\n",
    "#plt.savefig('Images/loss_Gauss_mixture')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "14e924c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "w = 1.\n",
    "\n",
    "ts = [0.8, 1.6, 3.2, 6.4, 12.8, 25.6]\n",
    "gauss_mixture.set_parameter(0.2)\n",
    "data = gauss_mixture.sample(4096)\n",
    "\n",
    "estimators_dict = {}\n",
    "estimators_dict64 = {}\n",
    "\n",
    "for i in range(50):\n",
    "    seed = np.random.randint(100000)\n",
    "    if 'mle' not in estimators_dict.keys():\n",
    "        estimators_dict['mle'] = []\n",
    "    else:\n",
    "        estimators_dict['mle'].append(minimize_scalar(mle_opt_fn, bounds = (0.01, 0.99), args = (data,), method='bounded').x) \n",
    "    m=8\n",
    "    for k in range(len(ts)):\n",
    "        t = ts[k]\n",
    "        if t not in estimators_dict.keys():\n",
    "            estimators_dict[t] = []\n",
    "        else:\n",
    "            estimators_dict[t].append(minimize_scalar(energy_discrepancy_opt_fn, bounds = (0.01, 0.99), args = (data, seed, m, t, w), method='bounded').x)  \n",
    "    m=64\n",
    "    for k in range(len(ts)):\n",
    "        t = ts[k]\n",
    "        if t not in estimators_dict64.keys():\n",
    "            estimators_dict64[t] = []\n",
    "        else:\n",
    "            estimators_dict64[t].append(minimize_scalar(energy_discrepancy_opt_fn, bounds = (0.01, 0.99), args = (data, seed, m, t, w), method='bounded').x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "46707281",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ts = [0.8, 1.6, 3.2, 6.4, 12.8, 25.6]\n",
    "set_pub()\n",
    "mse_dict = {}\n",
    "mse_dict64 = {}\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "for t in estimators_dict.keys():\n",
    "    results = torch.tensor(estimators_dict[t])\n",
    "    mean = results.mean()\n",
    "    std = results.std()\n",
    "    mse = (results - 0.2).pow(2).mean()\n",
    "    mse_dict[t] = mse\n",
    "\n",
    "for t in estimators_dict64.keys():\n",
    "    results = torch.tensor(estimators_dict64[t])\n",
    "    mean = results.mean()\n",
    "    std = results.std()\n",
    "    mse = (results - 0.2).pow(2).mean()\n",
    "    mse_dict64[t] = mse\n",
    "\n",
    "\n",
    "ax.plot(ts, [mse_dict[t] for t in ts], '+', markersize = 10, label = f'M = 8')\n",
    "ax.plot(ts, [mse_dict64[t] for t in ts], '*', markersize = 10, label = f'M = 64')\n",
    "ax.axhline(mse_dict['mle'], linestyle='--', label = f'MLE', color = 'green')\n",
    "ax.set_ylabel('MSE')\n",
    "ax.set_xlabel('t')\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "plt.legend(fontsize=13, frameon=False)\n",
    "plt.grid(linestyle='--', linewidth=0.5, alpha=0.5)\n",
    "#plt.savefig('Images/Mixture_estimates_MSE_t')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "09b56439",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
