{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "HysRBep9XkWM"
   },
   "source": [
    "# Contour Stochastic Gradient Langevin Dynamics"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "2vGqaEV_XnCl"
   },
   "source": [
    "## Preliminaries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 20082,
     "status": "ok",
     "timestamp": 1612477412436,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "mYsmrtFjXezW",
    "outputId": "0a30cf04-56d9-4860-c34d-f1ca4f0dbd06"
   },
   "outputs": [],
   "source": [
    "import autograd.numpy as np\n",
    "from autograd import grad\n",
    "from autograd.numpy import log, sqrt, sin, cos, exp, pi, prod\n",
    "from autograd.numpy.random import normal, uniform\n",
    "\n",
    "import matplotlib as mpl\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib import cm\n",
    "import imageio\n",
    "import os\n",
    "from google.colab import drive\n",
    "drive.mount('/content/drive')\n",
    "\n",
    "path = \"/content/drive/My Drive\"\n",
    "\n",
    "os.chdir(path)\n",
    "os.listdir(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "executionInfo": {
     "elapsed": 215,
     "status": "ok",
     "timestamp": 1612477413492,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "EGDm-0ChXp3Q"
   },
   "outputs": [],
   "source": [
    "np.set_printoptions(precision=3)\n",
    "np.set_printoptions(suppress=True)\n",
    "np.random.seed(2021)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "B0lLhSOkXv_m"
   },
   "source": [
    "Build a non-convex energy function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 576,
     "status": "ok",
     "timestamp": 1612477415049,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "81_Xq2tUXtCe"
   },
   "outputs": [],
   "source": [
    "def mixture(x):\n",
    "    energy = ((x[0]**2 + x[1]**2)/10 - (cos(2.0*pi*x[0]) + cos(2.0*pi*x[1]))) / 0.5 # 2\n",
    "    regularizer = ((x[0]**2 + x[1]**2) > 20) * ((x[0]**2 + x[1]**2) - 20)\n",
    "    return energy + regularizer\n",
    "\n",
    "def mixture_expand(x, y): return mixture([x, y])\n",
    "def function_plot(x, y): return np.exp(-mixture([x, y]))\n",
    "\n",
    "lower, upper = -2.5, 2.5\n",
    "axis_x = np.linspace(lower, upper, 500)\n",
    "axis_y = np.linspace(lower, upper, 500)\n",
    "axis_X, axis_Y = np.meshgrid(axis_x, axis_y)\n",
    "\n",
    "energy_grid = mixture_expand(axis_X, axis_Y)\n",
    "prob_grid = function_plot(axis_X, axis_Y)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "18kaBnxvX0xj"
   },
   "source": [
    "Establish the upper and lower bound for the partions."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 464,
     "status": "ok",
     "timestamp": 1612477417948,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "r5R5inTOY6LU"
   },
   "outputs": [],
   "source": [
    "lower_bound, upper_bound = np.min(energy_grid) - 1, np.max(energy_grid) + 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "nQr4slgoX3UG"
   },
   "source": [
    "## Build Our Sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 323,
     "status": "ok",
     "timestamp": 1612477418377,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "hzGeKMALXs_c"
   },
   "outputs": [],
   "source": [
    "class Sampler:\n",
    "    def __init__(self, f=None, dim=None, boundary=None, xinit=None, \\\n",
    "                 partition=None, lr=0.1, T=1.0, zeta=1, decay_lr=100., parts=100, theta_init=[]):\n",
    "        self.f = f\n",
    "        self.dim = dim\n",
    "        self.lr = lr\n",
    "        self.T = T\n",
    "        self.zeta = zeta\n",
    "        self.decay_lr = decay_lr\n",
    "        self.parts = parts\n",
    "        \n",
    "        self.partition = partition # [energy lower bound, energy upper bound] -- U(x)\n",
    "        self.boundary = boundary # Domain boundary of X\n",
    "        \n",
    "        # initialization for CSGLD\n",
    "        self.x = np.array(xinit)\n",
    "        if not theta_init:\n",
    "            self.Gcum = np.array(range(self.parts, 0, -1)) * 1.0 / sum(range(self.parts, 0, -1))\n",
    "        else:\n",
    "            self.Gcum = np.array(theta_init)\n",
    "        self.div_f = (self.partition[1] - self.partition[0]) / self.parts\n",
    "        self.J = self.parts - 2\n",
    "\n",
    "    \n",
    "    def in_domain(self, beta): \n",
    "        return sum(map(lambda i: beta[i] < self.boundary[0] or beta[i] > self.boundary[1], range(self.dim))) == 0\n",
    "\n",
    "    def stochastic_grad(self, beta):  return grad(self.f)(beta) + 0.25*normal(size=self.dim)\n",
    "\n",
    "    def stochastic_f(self, beta): return self.f(beta.tolist()) + 0.25*normal(size=1)\n",
    "\n",
    "    # find the partition index J\n",
    "    def find_idx(self, beta): \n",
    "        return(min(int((self.stochastic_f(beta) - self.partition[0]) / self.div_f), self.parts - 2))\n",
    "    \n",
    "    def csgld_step(self, iters):        \n",
    "        self.grad_mul = 1 + self.zeta * self.T * (np.log(self.Gcum[self.J+1]) - np.log(self.Gcum[self.J])) / self.div_f\n",
    "        proposal = self.x - self.lr * self.grad_mul * self.stochastic_grad(self.x) + sqrt(2. * self.lr * self.T) * normal(size=self.dim)\n",
    "        \n",
    "        if self.in_domain(proposal):\n",
    "            self.x = proposal\n",
    "        self.J = self.find_idx(self.x)\n",
    "        \n",
    "        step_size = min(self.decay_lr, 1./(iters**0.6+100))\n",
    "        self.Gcum[:self.J] = self.Gcum[:self.J] + step_size * self.Gcum[self.J]**self.zeta * (-self.Gcum[:self.J])\n",
    "        self.Gcum[self.J] = self.Gcum[self.J] + step_size * self.Gcum[self.J]**self.zeta * (1 - self.Gcum[self.J])\n",
    "        self.Gcum[(self.J+1):] = self.Gcum[(self.J+1):] + step_size * self.Gcum[self.J]**self.zeta * (-self.Gcum[(self.J+1):])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "EmShRC4DYHX4"
   },
   "source": [
    "## Call Our Sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 2677,
     "status": "ok",
     "timestamp": 1612477423404,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "wM7xjsJmXs8l"
   },
   "outputs": [],
   "source": [
    "zeta = 0.75\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/result/'\n",
    "import pickle\n",
    "f = open(PATH + 'initialization.txt', 'rb')\n",
    "theta = pickle.load(f)\n",
    "sampler = Sampler(f=mixture, dim=2, boundary=[lower, upper], xinit=[2.,2.], \\\n",
    "                  partition=[lower_bound, upper_bound], lr=3e-3, T=1, zeta=zeta, decay_lr=3e-3, parts=100, theta_init=theta)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "2lVRu7dxaA8t"
   },
   "source": [
    "##Compute the exact energy *PDF*"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "executionInfo": {
     "elapsed": 365,
     "status": "ok",
     "timestamp": 1612477423784,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "t2bubVC8aEyx"
   },
   "outputs": [],
   "source": [
    "exact_energy_pdf = []\n",
    "energy_unit = (upper_bound - lower_bound) * 1.0 / sampler.parts\n",
    "exact_energy_grids = lower_bound + np.arange(sampler.parts) * energy_unit\n",
    "\n",
    "fine_axis_x = np.linspace(lower, upper, 500)\n",
    "fine_axis_y = np.linspace(lower, upper, 500)\n",
    "fine_axis_X, fine_axis_Y = np.meshgrid(fine_axis_x, fine_axis_y)\n",
    "\n",
    "fine_energy_grid = mixture_expand(fine_axis_X, fine_axis_Y)\n",
    "fine_prob_grid = function_plot(fine_axis_X, fine_axis_Y)\n",
    "fine_prob_grid /= fine_prob_grid.sum()\n",
    "for ii in range(sampler.parts):\n",
    "    tag = (fine_energy_grid > lower_bound + ii * energy_unit) & (fine_energy_grid < lower_bound + (ii + 1) * energy_unit)\n",
    "    exact_energy_pdf.append(fine_prob_grid[tag].sum())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "czoNLB-5YMfU"
   },
   "source": [
    "## Simulate from a flat density and record the importance weights¶\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "executionInfo": {
     "elapsed": 275,
     "status": "ok",
     "timestamp": 1612237161996,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "vuVttfdtXs5Q"
   },
   "outputs": [],
   "source": [
    "warm_up = 5000\n",
    "csgld_x = np.array([sampler.x])\n",
    "importance_weights = [0.,]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "16VT7iYqsRa2OIOiNLRj7HcLkMGUSljl4"
    },
    "executionInfo": {
     "elapsed": 458059,
     "status": "ok",
     "timestamp": 1612237620283,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "TAmWHy_VXs1Y",
    "outputId": "777155ba-22dc-4347-b24d-9ab9e5dcce71"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3, my_images4 = [], []\n",
    "history_samples = np.zeros(shape=(0,80))\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/result/single/'\n",
    "if not os.path.isdir(PATH):\n",
    "    try:\n",
    "        os.makedirs(PATH)\n",
    "    except OSError as exc:  # Python >2.5\n",
    "        if exc.errno == errno.EEXIST and os.path.isdir(PATH):\n",
    "            pass\n",
    "        else:\n",
    "            raise\n",
    "\n",
    "for iters in range(int(4e5)):\n",
    "    sampler.csgld_step(iters)\n",
    "    if iters > warm_up:\n",
    "        if iters % 20 == 0:\n",
    "            csgld_x = np.vstack((csgld_x, sampler.x))\n",
    "            importance_weights.append(sampler.Gcum[sampler.J]**zeta)\n",
    "        \n",
    "        if iters % 5000 == 0 and len(csgld_x[:,1]) > 5:\n",
    "            history_samples = np.vstack((history_samples, sampler.Gcum[:80]))\n",
    "            col_std = np.std(history_samples, 0) / sqrt(history_samples.shape[0])\n",
    "            \n",
    "            #plt.subplot(1, 2, 2).set_title('Energy PDF estimate', fontsize=18)\n",
    "            fig4=plt.figure(figsize=(4,4.2), frameon=False)\n",
    "            plt.cla()  \n",
    "            #plt.rcParams['legend.title_fontsize'] = 'small'\n",
    "            plt.plot(sampler.Gcum[:80], color='red', label=\"Estimation\", linewidth=1.5)\n",
    "            plt.plot(exact_energy_pdf[:80], color='black', label=\"Ground truth\", linewidth=1.5)\n",
    "            plt.legend(loc=\"upper right\", prop={'size': 13})\n",
    "            plt.ylim([0, 0.07])\n",
    "            plt.gca().axes.xaxis.set_visible(False)\n",
    "            plt.gca().axes.yaxis.set_visible(False)\n",
    "            #plt.xticks([0, 15, 30, 45, 60], np.round((map(exact_energy_grids.__getitem__, [0, 15, 30, 45, 60])), 1), fontsize=13)\n",
    "            #plt.yticks([0, 0.04, 0.08, 0.12], fontsize=18)\n",
    "            #plt.xlabel(\"Energy\", fontsize=13)\n",
    "            #plt.ylabel(\"Energy PDF\", fontsize=13)\n",
    "            plt.annotate(\"Higher energy\", fontsize=14, xy=(55, 0.005), xytext=(25, 0.03), arrowprops=dict(arrowstyle=\"->\"))\n",
    "            plt.title('Energy PDF estimate', fontsize=22)\n",
    "            plt.fill_between(range(80), sampler.Gcum[:80]-15*col_std, sampler.Gcum[:80]+15*col_std, color='red', alpha=.3)\n",
    "\n",
    "            plt.tight_layout()\n",
    "            plt.show()\n",
    "            fig4.canvas.draw()       # draw the canvas, cache the renderer\n",
    "            image4 = np.frombuffer(fig4.canvas.tostring_rgb(), dtype='uint8').reshape(fig4.canvas.get_width_height()[::-1] + (3,))\n",
    "            my_images4.append(image4)\n",
    "\n",
    "        if iters % 5000 == 0:\n",
    "            fig3 = plt.figure(figsize=(4, 4))\n",
    "            plt.contour(axis_X, axis_Y, prob_grid, 10)\n",
    "            plt.yticks([-4, -2, 0, 2, 4]) \n",
    "            plt.scatter(csgld_x[:,0], csgld_x[:,1], marker='.', s=3, color='k', label=\"Iteration=\"+str(iters)) \n",
    "            plt.legend(loc=\"upper left\", prop={'size': 10})\n",
    "            plt.xlim([lower, upper])\n",
    "            plt.ylim([lower, upper])\n",
    "            plt.tight_layout()\n",
    "            # plt.show()\n",
    "            fig3.canvas.draw()\n",
    "            image3 = np.frombuffer(fig3.canvas.tostring_rgb(), dtype='uint8').reshape(fig3.canvas.get_width_height()[::-1] + (3,))\n",
    "            my_images3.append(image3)\n",
    "\n",
    "imageio.mimsave(PATH + 'CSGLD_contour_'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.gif', my_images3, fps=50)      \n",
    "imageio.mimsave(PATH + 'CSGLD_PDF'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.gif', my_images4, fps=50)\n",
    "\n",
    "# save the sampels\n",
    "import pickle\n",
    "f = open(PATH + 'CSGLD_samples'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.txt', 'wb')\n",
    "pickle.dump(csgld_x, f)\n",
    "f.close()  \n",
    "f = open(PATH + 'CSGLD_importance weight'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.txt', 'wb')\n",
    "pickle.dump(importance_weights, f)\n",
    "f.close()  "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "dft27KaXYXW6"
   },
   "source": [
    "## Resampling via importance weights"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "7TiO31XXYY4i"
   },
   "source": [
    "Note that the flat density is not what we want. To recover the original density, we need to reweight the samples according to the importance weights."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "executionInfo": {
     "elapsed": 888,
     "status": "ok",
     "timestamp": 1612477641373,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "-ryilZe7XslI"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/result/single/'\n",
    "f = open(PATH + 'CSGLD_samples'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.txt', 'rb')\n",
    "csgld_x = pickle.load(f)\n",
    "f.close()\n",
    "f = open(PATH + 'CSGLD_importance weight'+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+'.txt', 'rb')\n",
    "importance_weights = pickle.load(f)\n",
    "f.close()\n",
    "\n",
    "scaled_importance_weights = importance_weights / np.mean(importance_weights)\n",
    "\n",
    "resample_x = np.empty((0,2))\n",
    "for i in range(len(csgld_x)):\n",
    "    while scaled_importance_weights[i] > 1:\n",
    "        tag = np.random.binomial(1, p=min(1, scaled_importance_weights[i]))\n",
    "        scaled_importance_weights[i] -= 1\n",
    "        if tag == 1:\n",
    "            resample_x = np.vstack((resample_x, csgld_x[i,]))\n",
    "    if scaled_importance_weights[i] > np.random.uniform(0, 1):\n",
    "        resample_x = np.vstack((resample_x, csgld_x[i,]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 459
    },
    "executionInfo": {
     "elapsed": 49479,
     "status": "ok",
     "timestamp": 1612477982198,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "nWhuJyoDYes7",
    "outputId": "e6988d88-708f-4389-f8e9-02563e71c193"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1676: UserWarning: `shade_lowest` is now deprecated in favor of `thresh`. Setting `thresh=0.05`, but please update your code.\n",
      "  warnings.warn(msg, UserWarning)\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1676: UserWarning: `shade_lowest` is now deprecated in favor of `thresh`. Setting `thresh=0.05`, but please update your code.\n",
      "  warnings.warn(msg, UserWarning)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x226.8 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(10, 3.15))\n",
    "plt.subplot(1, 3, 1).set_title('(a) Ground truth')\n",
    "sns.heatmap(prob_grid, cmap=\"Blues\", cbar=False, xticklabels=False, yticklabels=False)\n",
    "\n",
    "warm_sample = 50\n",
    "split_ = 1\n",
    "plt.subplot(1, 3, 2).set_title('(b) CSGLD (before resampling)')\n",
    "ax = sns.kdeplot(csgld_x[:,0][::split_][warm_sample:], csgld_x[:,1][::split_][warm_sample:],  cmap=\"Blues\", shade=True, shade_lowest=False, bw=0.15)\n",
    "ax.set_xlim(upper, lower)\n",
    "ax.set_ylim(upper, lower)\n",
    "\n",
    "plt.subplot(1, 3, 3).set_title('(c) CSGLD (after resampling)')\n",
    "ax = sns.kdeplot(resample_x[:,0][::split_][warm_sample:], resample_x[:,1][::split_][warm_sample:], cmap=\"Blues\", shade=True, shade_lowest=False, bw=0.15)\n",
    "ax.set_xlim(upper, lower)\n",
    "ax.set_ylim(upper, lower)\n",
    "\n",
    "plt.savefig(PATH + \"single_\"+str(zeta)+\"_\"+str(sampler.lr)+\"_\"+str(sampler.T)+\".png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 47726,
     "status": "ok",
     "timestamp": 1612477932308,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "1zXdrKzUDP8h",
    "outputId": "b46a7d3f-68db-471d-efed-55243bac50e8"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/_decorators.py:43: FutureWarning: Pass the following variable as a keyword arg: y. From version 0.12, the only valid positional argument will be `data`, and passing other arguments without an explicit keyword will result in an error or misinterpretation.\n",
      "  FutureWarning\n",
      "/usr/local/lib/python3.6/dist-packages/seaborn/distributions.py:1657: FutureWarning: The `bw` parameter is deprecated in favor of `bw_method` and `bw_adjust`. Using 0.15 for `bw_method`, but please see the docs for the new parameters and update your code.\n",
      "  warnings.warn(msg, FutureWarning)\n"
     ]
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "ax = sns.kdeplot(csgld_x[:,0][::split_][warm_sample:], csgld_x[:,1][::split_][warm_sample:],  cmap=\"Blues\", shade=True, thresh=0.05, bw=0.15)\n",
    "ax.set_xlim(lower, upper)\n",
    "ax.set_ylim(lower, upper)\n",
    "\n",
    "plt.savefig(\"anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/simulation_figures/CSGLD_before.png\")\n",
    "plt.close()\n",
    "\n",
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "ax = sns.kdeplot(resample_x[:,0][::split_][warm_sample:], resample_x[:,1][::split_][warm_sample:], cmap=\"Blues\", shade=True, thresh=0.05, bw=0.15)\n",
    "ax.set_xlim(lower, upper)\n",
    "ax.set_ylim(lower, upper)\n",
    "plt.savefig(\"anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/simulation_figures/CSGLD_after.png\")\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "ikRGsyEFlMss"
   },
   "source": [
    "## Calculate the KL divergence"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "executionInfo": {
     "elapsed": 41099,
     "status": "ok",
     "timestamp": 1612237661597,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "_YqHGrColGne"
   },
   "outputs": [],
   "source": [
    "def KLdivergence(x, y):\n",
    "    \"\"\"Compute the Kullback-Leibler divergence between two multivariate samples.\n",
    "    Parameters\n",
    "    ----------\n",
    "    x : 2D array (n,d)\n",
    "      Samples from distribution P, which typically represents the true\n",
    "      distribution.\n",
    "    y : 2D array (m,d)\n",
    "      Samples from distribution Q, which typically represents the approximate\n",
    "      distribution.\n",
    "    Returns\n",
    "    -------\n",
    "    out : float\n",
    "      The estimated Kullback-Leibler divergence D(P||Q).\n",
    "    References\n",
    "    ----------\n",
    "    Pérez-Cruz, F. Kullback-Leibler divergence estimationx of\n",
    "  continuous distributions IEEE International Symposium on Information\n",
    "  Theory, 2008.\n",
    "    \"\"\"\n",
    "    from scipy.spatial import cKDTree as KDTree\n",
    "\n",
    "    # Check the dimensions are consistent\n",
    "    x = np.atleast_2d(x)\n",
    "    y = np.atleast_2d(y)\n",
    "\n",
    "    n,d = x.shape\n",
    "    m,dy = y.shape\n",
    "\n",
    "    assert(d == dy)\n",
    "\n",
    "\n",
    "    # Build a KD tree representation of the samples and find the nearest neighbour\n",
    "    # of each point in x.\n",
    "    xtree = KDTree(x)\n",
    "    ytree = KDTree(y)\n",
    "\n",
    "    # Get the first two nearest neighbours for x, since the closest one is the\n",
    "    # sample itself.\n",
    "    r = xtree.query(x, k=2, eps=.01, p=2)[0][:,1]\n",
    "    s = ytree.query(x, k=1, eps=.01, p=2)[0]\n",
    "\n",
    "    # There is a mistake in the paper. In Eq. 14, the right side misses a negative sign\n",
    "    # on the first term of the right hand side.\n",
    "    return -np.log(r/s).sum() * d / n + np.log(m / (n - 1.))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "executionInfo": {
     "elapsed": 41093,
     "status": "ok",
     "timestamp": 1612237661598,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "3IJUFc0AlRAI"
   },
   "outputs": [],
   "source": [
    "PATH = \"anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/\"\n",
    "import pickle\n",
    "f = open(PATH + \"simulation_figures/true_samples.txt\", 'rb')\n",
    "true_samples = pickle.load(f)\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 215
    },
    "executionInfo": {
     "elapsed": 291,
     "status": "error",
     "timestamp": 1612322871718,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "f7pCAWAalUQv",
    "outputId": "f73ee3a9-c826-4b28-cbf0-84221ccc17c1"
   },
   "outputs": [],
   "source": [
    "csgld_kl_path = []  \n",
    "for i in range(100, resample_x.shape[0]):\n",
    "    csgld_kl_path.append(KLdivergence(true_samples, resample_x[:i,:]))\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "PATH = \"anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/simulation_figures/\"\n",
    "import pickle\n",
    "f = open(PATH + 'csgld_kl.txt', 'wb')\n",
    "pickle.dump(csgld_kl_path, f)\n",
    "f.close()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyMQQvfVZ8Q1yMd1QSaF9SbG",
   "name": "CSGLD.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
