{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 26965,
     "status": "ok",
     "timestamp": 1611724623670,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "y_CRtlvwpjcC",
    "outputId": "ddf44dee-0193-4374-c869-c2686807037f"
   },
   "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": 2,
   "metadata": {
    "executionInfo": {
     "elapsed": 311,
     "status": "ok",
     "timestamp": 1611724625346,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "AxdrQGlHJ2QC"
   },
   "outputs": [],
   "source": [
    "np.set_printoptions(precision=3)\n",
    "np.set_printoptions(suppress=True)\n",
    "np.random.seed(2021)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "executionInfo": {
     "elapsed": 287,
     "status": "ok",
     "timestamp": 1611724630327,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "CmqfVEJHSwvX"
   },
   "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": "cWJPHnxfS899"
   },
   "source": [
    "# Build SGLD Sampler (Single Chain)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "bY8TaMxWS7Wf"
   },
   "outputs": [],
   "source": [
    "class Sampler:\n",
    "    def __init__(self, f=None, dim=None, xinit=None, lr=0.1, T=1.0, decay_lr=100.):\n",
    "        self.f = f\n",
    "        self.dim = dim\n",
    "        self.lr = lr\n",
    "        self.T = T\n",
    "        self.decay_lr = decay_lr\n",
    "      \n",
    "         \n",
    "        # initialization for SGLD\n",
    "        self.x = np.array(xinit)\n",
    "        \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",
    "    def sgld_step(self, iters):  \n",
    "        self.x = self.x - self.lr * self.stochastic_grad(self.x) + sqrt(2. * self.lr * self.T) * normal(size=self.dim) "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "cfYrga2GDafc"
   },
   "source": [
    "## Call our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "53tl_ZNZDZjv"
   },
   "outputs": [],
   "source": [
    "sampler = Sampler(f=mixture, dim=2, xinit=[0.,0.], lr=3e-3, T=1, decay_lr=3e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ACAQESjbDov4"
   },
   "outputs": [],
   "source": [
    "warm_up = 1000\n",
    "sgld_x = np.array([sampler.x])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1rDgtTJj5Uhbfgb-SIPyAvTiErQXGH-cX"
    },
    "executionInfo": {
     "elapsed": 401765,
     "status": "ok",
     "timestamp": 1610229876061,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "kZOOL0wuDu27",
    "outputId": "8ff2c9b7-ad7c-4e7a-e24c-7507f1d07b5c"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SGLD_result/'\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.sgld_step(iters)\n",
    "    if iters > warm_up:\n",
    "        if iters % 20 == 0:\n",
    "            sgld_x = np.vstack((sgld_x, sampler.x))\n",
    "        if iters % 2000 == 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(sgld_x[:,0], sgld_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",
    "              plt.close('all')\n",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'SGLD_contour_'+str(sampler.lr)+\"_\"+str(sampler.T)+'.gif', my_images3, fps=50)      \n",
    "# imageio.mimsave(PATH+'CSGLD_PDF'+str(zeta)+\"_\"+str(psampler.lr)+\"_\"+str(psampler.T)+'.gif', my_images4, fps=50)\n",
    "\n",
    "# save the sampels\n",
    "import pickle\n",
    "f = open(PATH + 'SGLD_samples.txt', 'wb')\n",
    "pickle.dump(sgld_x, f)\n",
    "f.close()\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 426595,
     "status": "ok",
     "timestamp": 1610229901229,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "VhOtNmKHEKaM",
    "outputId": "d6c83831-3f31-4533-9f01-90330e961df2"
   },
   "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:1659: 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"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 540x226.8 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7.5, 3.15))\n",
    "plt.subplot(1, 2, 1).set_title('(a) Ground truth')\n",
    "sns.heatmap(prob_grid, cmap=\"Blues\", cbar=False, xticklabels=False, yticklabels=False).invert_yaxis()\n",
    "\n",
    "warm_sample = 50\n",
    "split_ = 1\n",
    "plt.subplot(1, 2, 2).set_title('(b) SGLD')\n",
    "ax = sns.kdeplot(sgld_x[:,0][::split_][warm_sample:], sgld_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(PATH+\"SGLD_\"+str(sampler.lr)+\"_\"+str(sampler.T)+\".png\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "bS1roQPKRhIr"
   },
   "source": [
    "# Build Parallel SGLD Sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 280,
     "status": "ok",
     "timestamp": 1611724650483,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "icsqdQ9nhiWV"
   },
   "outputs": [],
   "source": [
    "class PSampler:\n",
    "    def __init__(self, f=None, dim=None, boundary=None, xinit=None, \\\n",
    "                 partition=None, lr=0.1, zeta=1.0, T=1.0, decay_lr=100., parts=100):\n",
    "        self.N = len(xinit) # number of parallel markov chain\n",
    "        self.f = f\n",
    "        self.dim = dim\n",
    "        self.lr = lr\n",
    "        self.T = T\n",
    "     \n",
    "        # initialization for SGLD\n",
    "        self.x = np.array(xinit)\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",
    "     \n",
    "    def sgld_step(self, iters):        \n",
    "        self.x = [self.x[i] - self.lr * self.stochastic_grad(self.x[i]) \n",
    "        + sqrt(2. * self.lr * self.T) * normal(size=self.dim) for i in range(self.N)]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "-jwJi7vNSS1j"
   },
   "source": [
    "Call our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 349,
     "status": "ok",
     "timestamp": 1611724654940,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "TwmbvrcQST7l"
   },
   "outputs": [],
   "source": [
    "psampler = PSampler(f=mixture, dim=2, xinit=[[0.,-1.],[0.,0.],[-1.,0.],[0.,1.],[1.,0.]], lr=3e-3, T=1, decay_lr=3e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 656,
     "status": "ok",
     "timestamp": 1611724661862,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "ctbwu5C-SbTw"
   },
   "outputs": [],
   "source": [
    "warm_up = 1000\n",
    "sgld_x = np.array(psampler.x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1AYfJJ0M_BTc7kWSl__MWiukzTiKUvRn8"
    },
    "executionInfo": {
     "elapsed": 409676,
     "status": "ok",
     "timestamp": 1611725163144,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "-OXcsUgPSkYu",
    "outputId": "d1bdb575-ae5d-4308-e370-610d7ee789f4"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SGLD_result/'\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",
    "np.random.seed(2021)\n",
    "for iters in range(int(8e4)):\n",
    "    psampler.sgld_step(iters)\n",
    "    if iters > warm_up:\n",
    "        if iters % 20 == 0:\n",
    "            sgld_x = np.vstack((sgld_x, psampler.x))\n",
    "        if iters % 400 == 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(sgld_x[:,0], sgld_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",
    "              plt.close('all')\n",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'Population_SGLD_contour_'+str(psampler.lr)+\"_\"+str(psampler.T)+'.gif', my_images3, fps=50)      \n",
    "# imageio.mimsave(PATH+'CSGLD_PDF'+str(zeta)+\"_\"+str(psampler.lr)+\"_\"+str(psampler.T)+'.gif', my_images4, fps=50)\n",
    "\n",
    "# save the sampels\n",
    "import pickle\n",
    "f = open(PATH + 'population_SGLD_samples.txt', 'wb')\n",
    "pickle.dump(sgld_x, f)\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 307
    },
    "executionInfo": {
     "elapsed": 25472,
     "status": "ok",
     "timestamp": 1611725188729,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "MzRxikcoSEBy",
    "outputId": "aa5a5ed3-b3aa-47a6-d8fe-a1861119d9ab"
   },
   "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"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAANMAAADKCAYAAAA/3nWKAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO1dX8imR3X/nd1uNhvWUuqm7ZKkXWmtGIp/F7F4ZwuNWioKgl4opYI3CgpCsXjdq4I3rVACigiiCCoVYkkVpKFUxY3Ekri1BEGMLJjoRQzZbEx2epHv+TLffOecOWfmzPvM++X5wQe77zvPzHnnmd+c+Xt+lFLChg0b+nFqbQM2bDgp2Mi0YUMQNjJt2BCEjUwbNgRhI9OGDUHYyLRhQxB+a41CL1y4kC5duiR+f3PQav0pkr+zlHmzYxvhFCmFO8q8ebOexlL+KaYbrdnIlcPZU6bX8i3tqNmQv8NR7aQsp8SDDz74RErp9vLzVch06dIlXLlyRfz+qRvjaun82aO1ZCnr+m+eDyv/3JnT5rRluc88+7z6vbf8W285botkH1dWaY/VprKM0g5PHY1G2V4AgIh+yqVdhUwaRhKpJX+tcXCNaQHXUJf8LI3FS6TrN2Rbzp19sby8/CXP3NYl3yWN9Pt7iF3WwTPPPn/MhkhCSbZZynjqRmIJxWEqMo0mkhfW3pgD11DLfLmXWSvTQ6IyzUKqWmOW7LDYo9lUkhrAEWJHEcpK7DydVpaVUNOQyUokraJG9mYaibQXbyGVBqnhcg32yWeeO/bZb9/64ivOSVVrzBH2lMjTcMS22iDm3zEcr5HXQqgpyBQ1b9F6fCss3ojtjZnPyt4fkId/HCwNlyNQjvz7hVjXbzzf1Jh7iJ2T2mqDxztFzGtr7adGqNXJNGIBoJVU3iFWix09HsBDIg5PPvNcE6G0zsRqk4fUZVnae2yd0y6QRgwaoSSsSqYakXp7m96erWeuUpsfALKX8hLp2tPXVVsA4OJt5w6ftRBKQquHzFGzgZs/AUc7pV4SlWm5OaO3M16NTKOJVObj7d165gZ5OmklbSkjf4mSB5AarYVEedqcUMALHsLiHUp7cps4Ekl2LeVrNizwLoosz7RCKs9DqFXI1LvZxlVabeikDSO0/CPmBoC+kibZq5XFNdgfXnvqyP9fe/H8kf/nhCpttAy38vSlPZJN3PeaDa2reBF7Xr0LIFMeJ9L2NqTGp30n5dtDpCefeY7tlaXP8+drL7nWcMtG+8NrTx0jUv55/l3+bJ6nZN/13zwfQiQpLVtXB+V5tyHy51uWx6W8rFh9AaKEdZNQQq13aanklrlBPoyR8q/1wJwnzBsiRyAJP7z21KGnKod8nI2e/aNeL7nYYB3uld/X7K4hapN4Ss9UwjsWbh07s0OFgBU0Li/AvsTeUi4HyUMdlq3MB63ztpqXzOHxZhxMWxY3nmf/jqXLnm0laDeZiOguIvo2Ef2IiB4hoo+25tVz4iDqOckODdeevm5uGGqDrczPWr3SKHBEqqGWZvndWuO2wto5RCHCMz0H4OMppbsBvBnAh4no7oB8d4oWr1SSSCKV5lkOV+wEAnPP9hCJe1bznuVn0m/pJbfX+/acVfSk8aCbTCmlaymlHxz8+9cArgK4ozdfoM+7jIbmibzDF4sn7B0Sbaij1xuGzpmI6BKA1wP4nvdZ76nj/E/CzGTUMGIIwmEGgrbYUF213VH9lQgjExGdB/AVAB9LKT3JfP8hIrpCRFeeePzxqGI3vESwDx1jCJmI6AxeINIXUkpf5dKklO5NKV1OKV2+cPuxS4obVgC3ebqPNkSdlulFxGoeAfgMgKsppU/1m1RHvieg7Q/07Gb3YIZGetKgvcuoqze1W8g1RHimtwB4P4C3EtFDB39v92birZBzZ06ver05kjDl7yg3LiNRbp4es2Vg2Rqkze0WrPUbIlbz/iulRCml16SUXnfw940I43o8i/dZNh5C5aWUhLp42zmWZHlDKfNciFTrGEZ6u1pDzm2W0tZIak23lKV5iagRRzTp9uIExK7BNWypES0Ekhq71lAtnpV73tpwtec4e72Nq8yjZlf5/ZreXerUgPYAL1ORiTO6pRcaNVfyDkXK9PkL5H7rkblgpTG0EqqE9TdZifbai+eP2cZ9lhNpsYErQ3qXlnd87uzp46RhPovCVGSS4CFHbaKa/2nPHg6/ioq3Nj4vkSzf9fTkXq+kzUnz3ybZtBCohfRWT2D1IAuBJBJFeCVgQjJJxlsI5V3xsVYURyiJVNx3ViJJ5UqN19JYyzScRzhWrrBaKs2dvCTv9UoaWhayorDKFQwtWqaG1uFbzRPk+xS33nL6cIMw/+7c2dPHdtYtXqpGpOU35ZuSpU1LWdL5tYUs+fk4j0ewDD+5eshtWgiinWgoScfVn7dx5++Ls1dDdDDM1e4znT9L4tV1a2VYYKmQHkKp+SqNlFuh4gjFlXnxtnNso60RqOYRPJ1Onk9OcquX4lY4W/d5vIQataWy6jBPC5sU8YNHbOZZJrBlmhqRap8viB5a5WgZfmr5aYjcU9JQzpG1eWDEotV0c6YcPWToHTvXXH4+qS3/PPmWqC2ClISykEpKo3UKt95yWq2D6IWZmleqbdJH70m2tL3VyVSLkuk96dBzMiJ6DB05nNAavkYoyzylRP67IwmlLcxYMePxsQWrkwmoEwqok2TU8aJWQvXsmXHeKQfXaEsvZfVa0dBWOU86pvmF2oJEjtHn8SyLH4sNngnu2r1mD7gJvgZt5fEkYwrPNDskIhybR614+LblCr20MlkSx3uXSAqBVsKzMjryMmhrzL0SU5HJqoMzK0a8aEu0otoV+vJ7LVbdgsXeCCJZvuu9Mq4F87TczI4g1FRk2jdIobp698hqwV1yWK99S4TSgmPWGhgXmLOGMkinVH5LvPDSTuk9SMTqvc07HZlm9E4tEUMjwpa1hkiWYteVXspCKMmeFiJJ6XsI1RPNlUt/oiK6ro3IcLmcaIA3QilQD5EshdmSjhfVoqlyEU49EW6tR4okNYwcWn1Zg1ByKMsqVUBaVAw3MjlgfVnaiwJkGRNNSoYjkjc8MgA1RHJJKA690jZl8H6OUF61kNLeESqGFkJNN8xbU9dW80pckEPppXHfSWP0/K8sK4pIOWpB/FtDJGtDTg41AQGtro7YJAgL5FjmaV5RBe+oZPNMAnr1mfK0mkbTsWeUF6YR6fP3XRWf+8A7Xn3k/7mX4mRmjsngKPMjS4hkKYh/7qUsHqpE6xxOUjEEcKxcSXiNA6W0e09w+fLldOXKFfa7tTyT5JUsvV4J9iBp5cyeVNaSv0QkjUQlSlIBLzZsyz2n3J7cJs4uC7h7VlK8jLy+tFDIrZvFnlPsv/eyMw+mlC6XeUw1zJuNSEfSGPWZpO/KoV8+PKlpIEUQaUkvPVPTTCo/jxARqMU9zyEtZ1vjwZd/Wrmt4gFTeSYrmaLvqUiVVs5dgLaez3PAcxSRSuReivNOwIt2awsNEpFK+zivqJWv3cBd0LsYUpYplbu0q8U7Te+ZeolU+877TKROEuel2DKN87FeIpVYCMFt7HqJJHk/zStyeS+w1FWviqF1IabmnfZqAcJClh4VOM/JA8B3RbtU6Cv3VbjGwXmlKCJ9/r6rrLeQdG9ze0qbPLYtafKyc1XDBaIie2WhwaJiCPiu9ZcLEhKm8EwWr9SyWdqarvc8nOV7IBubr6TakKOmKhhBJAuketO2IqRntaV5TcXQsk3AYQoy1bBWYPZR5+G0MnbhlaLza8mnfMazGMF9P0LF0IsoFYzPEtEviOjhiPwiEEnA2nk4DTNoILWgvM6xYAb5T0AnWsvJEEB/V5b2FOWZPgfgnqC8VsGu9H9aryjsAtzQp9YZRHvLFozssDxDvRAypZQeAPCrlmdn2VuaHTM02mhY9rz2CTubM+XKgY9vyoEbBmHNYejOyJQrB96+A+XANbWbNtggbeRGxVSPgCeC0l6s5o3AWmSbOUrPSMmXfYelvaxOphlv1kbC0yA1omnHcUZgsXtNQlk7npHqIB5ELY1/EcB3ALyKiB4jog9G5LtgF8EfraG4PBXeEgByl4ggaGse5XPe4ZlWl9FDPSuiVvPel1K6mFI6k1K6M6X0mYh8W+CN/mpB+eJ6QhIfKX+g8JYXWg9dytiMBHcVA/BHf7XYWZPa8QoKrD7Ms8KqZhFZlqbl6glJzD1/5FQyU86SR/7CI4d63sm/9nu9dnm90mGjVsIxc/ZJ+baKsNUwxbjDE811pEyIN3Jpi3wKwPeyXrmaHkiN2fp7Xnvx/LEl6A+849XVvTDtcmJeviqoXdRTqRFV7lFZSBPhlYA98kwLehQArfnln1uUxjW0DFd25Z3KvEsbNG/MPfeBd7z68I/7XINHsLpVxKCWXnu/ljn1NJcDZwyk4glvVcJydZ21ZfDlQO5SIFBvVNG3bPPyLZcCuVFJVMixvNy8bO+19Y1MB6jdtgVsQTtEndhKDIgt/oNdzTAyGGZebl62Nryb/qatFVzs6IiQxDmsy+TLUCj/41A2jtahajm0sgyflnRSXlYiad97J/O1edKC2hAciFUx7BWp3ivP1CL6a4U1Zp53kcASlYizQ/JOQP/5sxqRjgXRVOLl5ajZpZ2w8GrsAm2Ro8ryDstSYj4cSXfmNF526ynWM02xmlcjUm9IYgs8ItFAnVTsip1TN/b6jecPV6vylSpuNc0KzovUemdNYT0nVJ53GUG2hFdjtyYCzb0Xq5fyiGRrWH2YF0mk8rmR1yy0xQQPkTzKhL2bp7WjM9bfZBGqbtnLkcpf6qims6vlYSlTmydNfzZvFJGi8xiFvJFwWF50xDEkbQm8Fz3L0RxqDTeCUCNOn6xGJo1INVEq7c+bX55mFoz0TmUeHqxx9EnqaCyE8uxT9XolYCUy3VQckqRrpJHFmjZy6GcNcJ+XPQK7PNQZdUKjdpO2VfSMw0Kq/G8UpliAWOBVritR9iCSto+lYdcUMGqwBO2PiDvRshDBycn0oOWaeU3SJhKcfMwITEMmj5yLJY8yaKBnv0Br5N7euaWBWJQwAH8UnpoX02yNWB63eFFOAYPrFK0d0TFpH8P72GuxM68ukoZSrKuHVGX5nt12KXqrZ+me02fqQU4oyTtxjS1qn8kiuCahRh5PO2mR+rFg9aXxcnycn4vLNzAtET3ztFz+SxkapMD9ZYOyBEiUdFs5u2qfA/HKE5rgGFfn2nGiiFh1ZSTV1si81tGD9k5a5FdXOQHxhjdeTg/89/dd6hNA2wFTbUNOk3aMUsCo2bTYJTUI6wkIj9gZ4DvkmtthscUDy2FXjzhcyyKJda9p+V46AbEame7/z+8e/n+0jIvniIrVhtqku3ZlvUVWBog97GollIdIXlLndvQceAV8R4qsnS5HqKlOjb/uDW9M33zgewD8ROo9Vg/YejrrPKEGq02H5Tt0bFuuYVgJxWEUqXM7NEIB8gXR1tPjljayd6fGLY3YojxREx7Oy5JsyGEhkjbU0YL353MSaU4YfZ9JC5iv1W8UkazpJSUKzht557NcOWVZLfuCq3qm8hKeplHkhfVENAfNOyzoOSFd2lRitGog4PNQkUSy2GC5vg7YvVFuv+R991rTVltV04i0rBxxfzksHoqD5h1yG2oobbJ2CrVedRcyMIutpaePJnUt1ri6GmogEjeakXRtWbkf50mM1Yd50v2dEpbl115C1Tyjdwm4tKm0p/yttXnSyOD9Wt1xGEHqWt1KWyTcvNrSeWnCai1Y52zezXqanp3+FkQsgbdgKatnkaMVHkKsFRDf+y566q5WVs07reqZRt0qtQyvjkw2DQqBPY2pZo/mjRfsQlLGKlk5UsFQEquW0NvxeQ7dAjvQtCWie4jox0T0KBF9IiLPEeBUzyMCcmyYA5EevWWo100mIjoN4NMA3gbgbgDvI6K7e/OdCTWv5O2prUvQa6D8rTPIbkodnLXjkxapFkTVeYRnehOAR1NKP0kpPQvgSwDeGZDvFC+yhoVI0UOfffjt+4Bd1mMEme4A8LPs/48dfHYEuXLgr375uHkVby2s7SFynEQJzpOIVZQDf/fl45UDe2G92r0L3aRdajOtJceioefyojfWeA8i7jP9HMBd2f/vPPhMxXLGqgxplaMnpBWHUfpI3sa+T4p80e+Aw+jOoqWDaLmRG+GZvg/glUT0CiK6BcB7AXw9IN9mWA5vemICrNFbv1TKlGywdDi7EI/zXBjsJlNK6TkAHwFwP4CrAL6cUnqkN99dolfpogbPyexdei2rR+DCMu8KnvfRUnee8NDADsTOUkrfSCn9aUrpj1NK/9ibX084K8sdHasLjwirVXvO2lhmHApFgFPl6NEB7pFJXVALhilh1RMQpQZSb2D4HiKNiFpjPTkeFRDfA42cF287d8zWEd6plkf53qSheYRMai1EsyV2yCpkOqWUWgp9LVjC7ZYvlfu81SNxpC69UwuxOZvKl2cJORzlnazXL0pSRRKq9/qFhVBcPXKfeyVlJKx+apxT6FtQi2PNNWyr616kXaQJpta4NVJx31nH5VyZ0R6h5aZtNKE8mraemO5c3S7kkcjVMvyXMNXlQEDexO2JuWC5sm5RCWzZyNWIdCTUlOH6R47IK+tS3WnvwBv/gSs/tyG3oxYDohb7YeSVdWDSGBAjAqkA7cFUIgnVElDFSyjARqpesbPRkYlyO2YPpgJMSiYgLsTXAiuRlorS4qN5NVM9V6IltBDKixbVwGhC9RApR48QnVaWNk+alkxAn4YsUBdj1uLleWzwekpLvDxrmaMacGnnqGiunA25HS1EOrSxMXae9j6kmHkA5o6bB+xG9rK2KtNL6gVecufwBJfpbcC5rS0ek7OJs6u2UORdTbMKOkhtxyspU34/PZmAfuWJHiLVbGiNC+DVtM3LHdmAAT02XW7HoV0dQTklO1qXpb0KKRpqI5fy++k0bblggpKOLMCvfKnLpg1E0mzIdV2taCFSXq5VSxaob/BahnXHBMMKUkn25PlLpLIuS1vfW03j1grLFMCKVVUwaj9e+r66+dqpZiDZYBWHztNqNmnDFwuhgPFbBrktyzO5PQBYUtUQsVHKEWpNTCEpk6OsIG9vE9HT1GyoeSnL5h9nl1SuxSNY0BN/PfdSZafCXZ+x2FDasQY4AbpW77T6CQgLIj1NVL6jzvjVxKKB8VcPFlVzT6PijkhxaSSMese7xF6QqQeqCuAAndko3dcFeSPrIZSUvubJtck413FI5w5rK5wtsGgolVpTFr3hFm0mYE/I5Gn0u1JN9wpEe9AzCZ4FC4GspPe+t1qD18TxuO9q5Vvsm55MLeTwqgV68/MIRLfYNGJSLc1pousqL6/8O1a2Uo+e+ulRDpSUL1qW3qeI6JrD8jJrbpvL29NIogSiewhVy683mpP1d3ht1CRdaoSy1E8LkTRCazZ4CbVOrPGUTESyum6JWBG9bu/Grdem1vH6Ai1ovcc75frCUtqWM5TeTmCxgbOntIXTaeLEEbjPPYSSMN3S+IIe192jou05AdGitl4rU4L39IGkSSQpq/eqjbcIjFntGEFqjx3W5fJp5kxaI/Z6BM0bWMfitZfVo7beqiK+5JujRTrFo1cl2RMx5GytHy+RJE2mmh1eTOGZpAY+yhss5Wlq65IN3obT6gksw0vPebhrT1+vbvBqNvVcTcmh2WCpH41o0R7b652m8UwLpMqyeoMjeVV6O2luoNnAobXns3ioyFu/rXq/ViJZdYdzaO/02FDfePC2VeysVz1wdc8UfY8o72GWfDzzgt4eePnMesyHs6lFqFq6jlEegM09VFlXnE3WIWmPl5S8t1Z+VCcjeWxpZDNcnykavZue0SIA0T2wNqdrWT3U7jVZ7zxxNnk8gRdRwgiWd+2RlKl5Jw2rkkm7v7SgNrSS0DK0iri/lMPTYLjGa8nTKlbdalcPahrAkSLeZX65DR6bLOVI6CITEb2HiB4hoptEdOyy1AiUJLKOjyPLb0XEqleOiHgQVpu8FxVz21qEtSPg8dgRbajXMz0M4N0AHui25ACtc6VRhBqlGxV9ILYGS2MebVMEoaJjUnBofeddCxAppasAQETuZ1tOI8wkQDYauyZbFF7Kioc7mzPlyoG/fOKJXRW7YcPOUCUTEX2LiB5m/ly6tbly4MsvXDgR1wx6sPYNUw4z2rQGWi9fVp9KKf1lU84DwAUSyb+bHZ6X1BLARYMUcCX61q6mNBih6qFd4bfaEWVLien2mWq3SSVlgxI98Q6kfLzwELzlkGlrg1ij4+kRWbCg9zdxz3vt6OqWiOhdAP4ZwO0A7iOih1JKf2V9XgvtpWFUY7DYoHlHDVrU1EMlEKF8LcyXRXPWQjqL3E5U2DEOIxUb8/ppEZ+zdnRdniml9LWU0p0ppbMppd/3EMmKlkqO8Eqah2wR0xLLEWLVlTZoGCFvMzrAiTU8Myf7I72bFgki6bkW9cDVz+axwQSL+UJPKKnDPIW4da2BDLm4dd7A/VKD5WyI8AbeQJRaiLOaPVY7cmixBq3h1nps6VUPnGrOpPXKljBS1phseRgrLaSVJRqQJqRVPufxkpwInKUXltAS0dViZ56/RfzaIn/ptaV15BARpjnH6p4JsIck9q6GHf7bUCkWGyQRMA5WDSCufO63tEZ1HR3RtayL0UExrbZE2LHAuo2zCplOMScmomJ89wTv95KaI1WPvE2pGRXdcHojuvZ2MJwdNVs4HS0PuT22cHZ49kP3InC/JcZ3Lba3tVI8pLZ4yhYxLauXHCkCt8DSiPP8rTehS1uswTCjRg/ekYPlu70K3G9d3eqNN95D6kMbOuVtPMNOIN5Llp9FdjAtduTfrTUlqHnw1edMJWG4lwfYLmhZlCakdFYvCRwnSi360C7kbUZ5SYstgP1gbsQIYhe2eIkETEAmoD7kW9J4YCWR1QaN1GIQf2NDydNFDn0l+6LIndvL6WdpNvTY0WOL5V21EAmYhEyAjVBWeInkscHiKXs8pJfU3iMvPQ24tEWy16ufZelkAL2jGWWLpxOfhkyA3JAA2/0n60tpsYHb3LUi2ktKaTRY7bUEd2npYKT8Pe8sqrOz2uIdDU1FJkBuJK1XNlqOxYz2klE2WBtOtKfkbCmfPzLHFN5BS+fn7eyOeSqnLR6scgLiVOVibgsBRuazIOoOVquXkGyQ8jt35vi5NikPrx21fJayve/AOhy32pLb4R2heLHacaLzZ3VG9RJh7eeB3eoslY0muhHP2jFFIMqWVc/mjSbUCMzUCGZAZH3M+L49mOqgK4fWOc8oROg8eWVirFhi7+V/VrtG2eTBWjZE1cf0ZFoLUS82WgVQevFiGOGg3+EhpgU99SLFjZfStnYwXpxIMo3q4SIbjilof2CaMt0M3mm0DVoHE1W3OaZbGp8B1p5PqmzrMFMTErDY4H3ZZXmcTIpVSICzp2bTbPViqQ8PVvVMT91I1TStPVVkD+dtNFZPIOXT02C8Wr9SGu+wyNLbr1kvmk1R+Z3IYd6CFkJZKtfT82l5celahh+ipq+kAZw93zJ0Hd2AuXS99aKJikd1vKuRaaRXGoUR5MzTWbwA12CqNlSkTHtWKKM85K7rpbRN62Cs730ltfV6mtGrUJa0tUZm6fW8NnjQo/UbYRM7FGv0kF70djBc2l6PfaKHeR5YxvtH/q+8sNrLbPUER4Y9Qhk1udKexqOlsQh5R3nImh0jYCH+S2I1T1sdkhAxtCrlJHtsqJVfEij/f0SAx955koSWepHs8Ih590i1SpjSM9VeVC7szAk8R5d3JG3jEKIXmo1RGlKt9dgz3PTaYO1gvGLiLbaU6FUO/Cci+l8i+h8i+hoR/U5PfhY0v3AHYSzyoL2IOhlhaRReFfoaouskevujpXOJ6Ph6PdM3AfxZSuk1AP4PwD90W9SI6GM7HGYQIFvDhhFzlBnqMloVsjfW+H+klBaLvgvgzn6TdovZlt8X7KJz2Dd45pBrIHLO9HcA/j0wvw0b9grVZR4i+haAP2C++mRK6d8O0nwSwHMAvqDk8yEAHwKAu+76wyZjNdTOVO3bXZnWa/L7gpOoUtitHEhEfwvgrwH8RUpJ3I5NKd0L4F4AeMMbLxu2bXlwjazncKI3MEkUZrlkaOlkRhPb2tFF2xGtCdW7mncPgL8H8DcppadjTKpjUa7QFCxGwB1Wq0OxMMoGQA8FnKOlLqM9zFo29ATsX9A7Z/oXAC8D8E0ieoiI/rUzPwDxQ7KeAJbls+YQzUq6yA7AIrUTje74GgM6mRyW3+yRstE+z9FV0ymlP+l5fhdoDT6ppq8oc9RCAFvRo8ohNpbGEMlWyZsaejsZT51IS99WT+3FtMeJIuYykSHDSlu48MS1EMDA2LlSrUfu9QiW+OsSqSx1E42o+OtWO6eMm7egp7J7Q11Zo3ueO3v68M+bZ57OEpsuT9Mzf9PKcOXJBa3M6iOibjiMrpPW+pg2bt6CNaMT9YTLbQkDbIl3VzYei0p6VOB+Ln1EjL6WTkbKz1InSzrNptrnHFYd5p0/S6ZLgj1hgD2ICEk8ImpoLc64p0euEakl1nj+nLdeLDZY38uoOrFi9TmTlVDAbjZevbGsaxgVT9u9aGLwBlKsceA4SSRBhVH1wtkxuk687W2KKxjWId+aaJVf4RAVT9s6LGwlkuX7lmGiVH5LvUh1opHSUifS81pbXd0zzQiph7PuwNcC2vfYsWt5Gy6d5KUA/jBq9FGvsl56vKSnPmqd/jRk8gz3dgGNUAu8x5paF1OsQ6waeohUs0krQ8unFb314h01WEZP05AJ2A2hlkqxLnxoY/A1G85S/q5E4KRnW/cCI+a/lg4vwh7rNGQqMo1GXilWUs2yeez1lLs6Re8h1YgFpF5S53lw8MznpyPTbMM9IIZQu7DD2iOPbNQRkBqw1i5aSFWz2bswNh2Zdo0ZyTsDyoa0izqqNV7Lu4oidcsKMylXkIaBiB4H8NOArC4AeCIgnwhstvA4ibb8UUrp9vLDVcgUBSK6klK6vLYdwGaLhJeSLVNs2m7YcBKwkWnDhiDsO5nuXduADJstPF4ytuz1nGnDhpmw755pw4ZpsNdkWiPWuduCKb0AAAGySURBVGLLe4joESK6SUSrrF4R0T1E9GMiepSIPrGGDZktnyWiXxDRw2vacWDLXUT0bSL60cE7+uiIcvaaTJgo1jmAhwG8G8ADaxRORKcBfBrA2wDcDeB9RHT3GrYc4HMA7lmx/BzPAfh4SuluAG8G8OERdbPXZJop1nlK6WpK6cdrlQ/gTQAeTSn9JKX0LIAvAXjnWsaklB4A8Ku1ys+RUrqWUvrBwb9/DeAqgDuiy9lrMhV4qcc6vwPAz7L/P4YBDWbfQUSXALwewPei857+bF5UrPNd2bJhXhDReQBfAfCxlNKT0flPT6aoWOe7sGVl/BzAXdn/7zz4bAMAIjqDF4j0hZTSV0eUsdfDvLVinU+K7wN4JRG9gohuAfBeAF9f2aYpQEQE4DMArqaUPjWqnL0mEwbFOm8BEb2LiB4D8OcA7iOi+3dZ/sFCzEcA3I8XJthfTik9sksbchDRFwF8B8CriOgxIvrgWrYAeAuA9wN460E7eYiI3h5dyHYCYsOGIOy7Z9qwYRpsZNqwIQgbmTZsCMJGpg0bgrCRacOGIGxk2rAhCBuZNmwIwkamDRuC8P8PMyyzff/algAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 226.8x226.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "\n",
    "warm_sample = 50\n",
    "split_ = 1\n",
    "plt.subplot(1, 1, 1)\n",
    "ax = sns.kdeplot(sgld_x[:,0][::split_][warm_sample:], sgld_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(PATH+\"population_SGLD.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 25285,
     "status": "ok",
     "timestamp": 1610230325344,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "a5VzbLHNSoV9",
    "outputId": "57e419b2-85b7-43dd-b94a-c51b62dfcfe0"
   },
   "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:1659: 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"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 540x226.8 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(7.5, 3.15))\n",
    "plt.subplot(1, 2, 1).set_title('(a) Ground truth')\n",
    "sns.heatmap(prob_grid, cmap=\"Blues\", cbar=False, xticklabels=False, yticklabels=False).invert_yaxis()\n",
    "\n",
    "warm_sample = 50\n",
    "split_ = 1\n",
    "plt.subplot(1, 2, 2).set_title('(b) population SGLD')\n",
    "ax = sns.kdeplot(sgld_x[:,0][::split_][warm_sample:], sgld_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(PATH+\"population_SGLD_\"+str(psampler.lr)+\"_\"+str(psampler.T)+\".png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "4lR89EaVxNLP"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyNfxFw9MrA1JXCrBE/XA+Pw",
   "name": "SGLD.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
}
