{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 401,
     "status": "ok",
     "timestamp": 1612404038437,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "2kOf_IhqnqQM",
    "outputId": "a05c3bf2-7f1d-4880-dbce-5d38e85b92dc"
   },
   "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",
    "from matplotlib.pyplot import MultipleLocator\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": 15,
   "metadata": {
    "executionInfo": {
     "elapsed": 345,
     "status": "ok",
     "timestamp": 1612404040137,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "OtnU1Fb6rGrI"
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "np.random.seed(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "executionInfo": {
     "elapsed": 538,
     "status": "ok",
     "timestamp": 1612404042617,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "46yL7HnoA4oy"
   },
   "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": "code",
   "execution_count": 17,
   "metadata": {
    "executionInfo": {
     "elapsed": 539,
     "status": "ok",
     "timestamp": 1612404042793,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "IQEPzD4DST1G"
   },
   "outputs": [],
   "source": [
    "class Sampler:\n",
    "    def __init__(self, f=None, dim=None, xinit=None,lr=[1e-3]*5, T=None, decay_lr=3e-3, init_var=25):\n",
    "        self.N = len(xinit)\n",
    "        self.f = f\n",
    "        self.dim = dim\n",
    "        self.lr = lr\n",
    "        self.T = T\n",
    "        self.unbiased_var = np.ones(self.N-1) * init_var\n",
    "        self.decay_lr = decay_lr\n",
    "        self.hat_var = np.ones(self.N-1) * init_var\n",
    "        self.swap = [0] * (self.N - 1)\n",
    "\n",
    "        # initialization\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",
    "    def resgld_step(self, iters):\n",
    "        self.x = [self.x[i] - self.lr[i] * self.stochastic_grad(self.x[i]) \n",
    "        + sqrt(2. * self.lr[i] * self.T[i]) * normal(size=self.dim) for i in range(self.N)]\n",
    "        self.swap = [0] * (self.N - 1)\n",
    "\n",
    "        for j in range(self.N-1):\n",
    "            if (iters+1) % 100 == 0:\n",
    "                loss_stat = []\n",
    "                for i in range(10):\n",
    "                    loss_stat.append(self.stochastic_f(self.x[j]))\n",
    "\n",
    "                step_size = min(self.decay_lr, 1./(iters**0.6+100))\n",
    "                self.unbiased_var[j] = np.var(loss_stat)\n",
    "                self.hat_var = (1-step_size) * self.hat_var + step_size * self.unbiased_var[j]\n",
    "                \n",
    "            integrand_corrected = min(1, exp((1/self.T[j+1] - 1/self.T[j]) * (self.stochastic_f(self.x[j+1])-self.stochastic_f(self.x[j]) - (1/self.T[j+1] - 1/self.T[j]) * self.hat_var[j]))[0])\n",
    "            # print(integrand_corrected)\n",
    "            \n",
    "            if np.random.uniform(0,1,1) < integrand_corrected:\n",
    "                self.x[j], self.x[j+1] = self.x[j+1], self.x[j]\n",
    "                self.swap[j] = 1\n",
    "            "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "JfnViD4boB02"
   },
   "source": [
    "## Call our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "executionInfo": {
     "elapsed": 369,
     "status": "ok",
     "timestamp": 1612404045989,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "uF9IPvWJn_58"
   },
   "outputs": [],
   "source": [
    "sampler = Sampler(f=mixture, dim=2, xinit=[[0.,-1.],[0.,0.],[-1.,0.],[0.,1.],[1.,0.]], lr=[0.001,0.002, 0.003, 0.004, 0.005], T=[1,2,3,4,5], decay_lr = 3e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1CbfgZs_XfWutqSZ-9XPpWYAbgjNQatJ3"
    },
    "executionInfo": {
     "elapsed": 404508,
     "status": "ok",
     "timestamp": 1612292605037,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "_d_s7c2URwPY",
    "outputId": "56871482-29bf-4af1-c4db-ccb561e8cb9b"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "warm_up = 1000\n",
    "nepoch = 8e4\n",
    "resgld_x = np.array(sampler.x)\n",
    "swap_rec = []\n",
    "\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/reSGLD_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(nepoch)):\n",
    "    sampler.resgld_step(iters)\n",
    "    if iters > warm_up:\n",
    "        swap_rec.append(sampler.swap)\n",
    "        if iters % 20 == 0:\n",
    "            resgld_x = np.vstack((resgld_x, sampler.x[0]))\n",
    "        if iters % 1000 == 0:\n",
    "              print(iters)\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(resgld_x[:,0], resgld_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_reSGLD_contour_'+str(sampler.lr)+\"_\"+str(sampler.T)+'.gif', my_images3, fps=50) \n",
    "\n",
    "import pickle\n",
    "f = open(PATH + \"swap_rec.txt\", 'wb')\n",
    "pickle.dump(swap_rec, f)\n",
    "f.close() \n",
    "f = open(PATH + \"samples.txt\", 'wb')\n",
    "pickle.dump(resgld_x, f)\n",
    "f.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 232
    },
    "executionInfo": {
     "elapsed": 757,
     "status": "error",
     "timestamp": 1612404052938,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "mDOuGsq4oTWB",
    "outputId": "82cbc5f5-33c3-4517-ce01-006cd6704c75"
   },
   "outputs": [],
   "source": [
    "fig = plt.figure(figsize=(7, 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 reSGLD')\n",
    "ax = sns.kdeplot(resgld_x[:,0][::split_][warm_sample:], resgld_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_reSGLD_\"+str(sampler.lr)+\"_\"+str(sampler.T)+\".png\")\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 410634,
     "status": "ok",
     "timestamp": 1612292616584,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "uAXKxTwKbxUq",
    "outputId": "1d256601-2c4e-451d-8fca-6fccd1298678"
   },
   "outputs": [],
   "source": [
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/'\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "plt.subplot(1, 1, 1)\n",
    "ax = sns.kdeplot(resgld_x[:,0][::split_][warm_sample:], resgld_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+\"simulation_figures/population_reSGLD.png\")\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "executionInfo": {
     "elapsed": 386,
     "status": "ok",
     "timestamp": 1612404056217,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "CmOqt05zSnIq"
   },
   "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 estimation 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": 21,
   "metadata": {
    "executionInfo": {
     "elapsed": 659,
     "status": "ok",
     "timestamp": 1612404057276,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "1MtqHLdN28gB"
   },
   "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": 11,
   "metadata": {
    "executionInfo": {
     "elapsed": 425527,
     "status": "ok",
     "timestamp": 1612239989511,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "TgNPhUhVSoY_"
   },
   "outputs": [],
   "source": [
    "resgld_kl = []\n",
    "resgld_epochs = []\n",
    "resgld_path = []\n",
    "resgld_epoch_path = []  \n",
    "for i in range(100, resgld_x.shape[0]):\n",
    "    resgld_path.append(KLdivergence(true_samples, resgld_x[:i,:]))\n",
    "resgld_kl.append(resgld_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "F-dKEvjgSuwe"
   },
   "outputs": [],
   "source": [
    "resgld_kl_array = np.array(resgld_kl)\n",
    "resgld_epoch_array = np.array(resgld_epochs)\n",
    "resgld_sd = np.array([np.std(resgld_kl_array[:,i]) for i in range(resgld_kl_array.shape[1])]) / np.sqrt(20)\n",
    "resgld_mu = np.array([np.mean(resgld_kl_array[:,i]) for i in range(resgld_kl_array.shape[1])]) \n",
    "resgld_lower = resgld_mu - 1.96 * resgld_sd\n",
    "resgld_upper = resgld_mu + 1.96 * resgld_sd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "1xw7dhVUVcWX"
   },
   "outputs": [],
   "source": [
    "x =  np.arange(7000, 4e5, 20)\n",
    "re_x = np.arange(6600, 4e5, 100)\n",
    "fig=plt.figure()\n",
    "plt.plot(np.linspace(5100, 100000, 854), resgld_mu, label=\"re sgld\")\n",
    "plt.fill_between(np.linspace(5100, 100000, 854), resgld_lower, resgld_upper,\n",
    "                 color = 'black', alpha = 0.15)\n",
    "\n",
    "\n",
    "plt.legend()\n",
    "plt.ylabel(\"KL divergence\")\n",
    "plt.xlabel(\"time steps\")\n",
    "plt.savefig(PATH + \"reSGLD_result/kl.png\")\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "MgU7Y6pHjad0"
   },
   "source": [
    "# Plot the swap process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "bcdrsCk38iMA"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "f = open(PATH + \"reSGLD_result/old_result/swap_rec.txt\", 'rb')\n",
    "swap_rec = pickle.load(f)\n",
    "swap_rec = np.array(swap_rec)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "9bX9v1hzwCTC"
   },
   "outputs": [],
   "source": [
    "swap_x, swap_y = [], []\n",
    "noswap_x, noswap_y = [], []\n",
    "route_x, route_y = [], []\n",
    "left, right = 70000, 70050\n",
    "\n",
    "# find route\n",
    "pointer = 0\n",
    "\n",
    "\n",
    "for i in range(left, right):\n",
    "    tmp, flag = None, False\n",
    "    for j in range(4):\n",
    "        if j == pointer - 1:\n",
    "            if pointer == 4 and swap_rec[i,j] == 0:\n",
    "                route_x += [i, i+1, None]\n",
    "                route_y += [pointer+1, pointer+1, None]\n",
    "                continue\n",
    "            if swap_rec[i,j] == 1:\n",
    "                pointer -= 1\n",
    "                route_x += [i, i+1, None]\n",
    "                route_y += [pointer+2, pointer+1, None]\n",
    "                continue\n",
    "        elif j == pointer:\n",
    "            if swap_rec[i,j] == 0:\n",
    "                route_x += [i, i+1, None]\n",
    "                route_y += [pointer+1, pointer+1, None]\n",
    "            else:\n",
    "                tmp = pointer + 1\n",
    "                flag = True\n",
    "        elif j > pointer and flag:\n",
    "            if swap_rec[i,j] == 0:              \n",
    "                break\n",
    "            else:\n",
    "                tmp += 1\n",
    "            \n",
    "    \n",
    "    if tmp:\n",
    "        route_x += [i, i+1, None]\n",
    "        route_y += [pointer+1, tmp+1, None]\n",
    "        pointer = tmp\n",
    "\n",
    "\n",
    "\n",
    "for i in range(left, right):\n",
    "    for j in range(4):\n",
    "        if swap_rec[i,j] == 1:\n",
    "            swap_x += [i, i+1, None, i, i+1, None]\n",
    "            swap_y += [j+1, j+2, None, j+2, j+1, None]\n",
    "            \n",
    "\n",
    "        else:\n",
    "            noswap_x += [i, i+1, None]\n",
    "            noswap_y += [j+1, j+1, None]\n",
    "            if j == 3:\n",
    "                noswap_x += [i, i+1, None]\n",
    "                noswap_y += [j+2, j+2, None]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 245
    },
    "executionInfo": {
     "elapsed": 675,
     "status": "ok",
     "timestamp": 1612121686971,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "gJrhh1aro5B7",
    "outputId": "a24e5c05-8c95-42ae-f93d-1d7e2e75b017"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:25: MatplotlibDeprecationWarning: Using a string of single character colors as a color sequence is deprecated. Use an explicit list instead.\n",
      "/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:28: MatplotlibDeprecationWarning: Using a string of single character colors as a color sequence is deprecated. Use an explicit list instead.\n"
     ]
    },
    {
     "data": {
      "image/png": "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OYJMnx/w5frA0kifRUN2iv/+Fy9WAwKkzAwpytVXX80/On8LwMGPm7nhhhvCfr81a9agVaexvnMzLfu6mZI7g/fefx+VSnmsccMNN/DhO++QnJyMXZL45JNPKC1V3qv35J/+xH3f/jaZWVm0dXXx/PPPc/kVVyja7t27l3PPO5vJSwoZ6BviimuuCVvmRYsWUVQyhWuaPmKg1UyymMnWLVvQG5SXMu+5+25efPZZ0jMyGDCb+WjjRubNU17qeO3VV7nxxhspzM1loL+fn//qV9zxxS8q2jY3N7Nq1SoMKpU8A3DRRbz44ouKtqIocsEFF7B/1y70Oh265GS2ffopmZmZivY/f+ABNjzxW+afPY3t7x7gh68rz5QDXHPNNXzmsqe49UInuz+q5547v859P/iBom1/fz8rVq7AkCegSVazcGkFZWVlirZGo5GL1q3jM7veQqPS0X1okE+2Rq7vx/74IJ/9zkqGHS7OTbmBK6+4auSDgOov45KCR0o9M53MWO6EwnVQEvyO2G021v/gMspWyc9qunaa3L5FF1g9AZmhwDf6uvz2y3l0kbw39IW7P+SDdz+MWN+fv+NW5q2dRsPeVu679wFFO5B927e//W1u6d/Goe3NrFlyFi/+7W+KtsdT3489/DAZmZl09fXx5r//zZo1axRtN2/ezLrPfpa8rCwG+vu55957I9b3yhUrcAwPY3c4mLNwIe+991749n399Wyu2ciMZSUMdbuV/XlmOXS8xbdumQf4B+kpV0K62gILfgGGnKA/2bt3L4988G1yC1IBsO3J4LGfPhF67z0/RrK2BA2kaw+bWTg1BdQGSAuY5ba2g62D1n6Bkmx/8Lm4zA6CBrSh+56vue5qNrpe5NGzOnnnt5V8/abvRG7fq1eRPzMdh9vBRevWYTQaFW3LysqYv2gpv1zeis6oobmqlz996x+h9d2zFY7+hUZz8Gy3y61BLbggYxF498VLIgzU4pY0aNR+3287082kVDtM+QLkrA66T39/P1/81bVMXZLNgU0tmPbrx17fHj537bWc8cgPmTyviD0b6/m/J5+O6M/PPussMlJSGBwY4Iabbx63/vuKa67hgu2vk56ZxtHqdj7870fj4s9HIuhCD8NMNHG1BAzyLMGf//xnenp6WL9+PdOnT49o/9prr1FZWclZZ53F+eefH9G2traWV155hbKy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\n",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "nepoch=4e5\n",
    "font1 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 11,\n",
    "}\n",
    "\n",
    "font2 = {'family' : 'Times New Roman',\n",
    "'weight' : 'normal',\n",
    "'size'   : 11,\n",
    "}\n",
    "\n",
    "plt.style.use(\"default\")\n",
    "axis_x = list(range(int(nepoch)))\n",
    "axis_X1, axis_Y1 = np.meshgrid(axis_x, axis_y)\n",
    "\n",
    "fig = plt.figure(figsize=(8, 2))\n",
    "ax=plt.gca()\n",
    "ax.yaxis.set_major_locator(y_major_locator)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "ax.spines['bottom'].set_visible(False)\n",
    "ax.spines['left'].set_visible(False)\n",
    "\n",
    "plt.ylim(0.7, 5.5)\n",
    "plt.scatter(axis_X1[:,left:right], axis_Y1[:,left:right],s=5,marker='o',c='', edgecolors='black')\n",
    "plt.plot(swap_x, swap_y,color='#6aa84f', alpha=1)\n",
    "plt.plot(noswap_x, noswap_y,color='#e06666', alpha=1)\n",
    "plt.scatter(route_x,route_y,s=20, marker='o',c='', edgecolors='#ffc85c')\n",
    "plt.plot(route_x,route_y,linewidth=2,color='#ffc85c')\n",
    "# plt.tick_params(labelsize=11)\n",
    "plt.tick_params(\n",
    "    axis='x',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    labelbottom=False) # labels along the bottom edge are off\n",
    "plt.tick_params(\n",
    "    axis='y',          # changes apply to the x-axis\n",
    "    which='both',      # both major and minor ticks are affected\n",
    "    bottom=False,      # ticks along the bottom edge are off\n",
    "    top=False,         # ticks along the top edge are off\n",
    "    left=False,\n",
    "    labelleft=False) # labels along the bottom edge are off\n",
    "# labels = ax.get_xticklabels() + ax.get_yticklabels()\n",
    "[label.set_fontname('Times New Roman') for label in labels]\n",
    "# plt.subplots_adjust(left = 0,top=1)\n",
    "\n",
    "fig.savefig(PATH + \"simulation_figures/population_reSGLD_swap_\"+str(sampler.lr)+\"_\"+str(sampler.T)+\".png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 1345,
     "status": "ok",
     "timestamp": 1612386327433,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "moG16ybuCm9J"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "PATH = \"anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SGLD_result/old_result/\"\n",
    "f = open(PATH + \"population_SGLD_samples.txt\",'rb')\n",
    "samples = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 408
    },
    "executionInfo": {
     "elapsed": 29350,
     "status": "ok",
     "timestamp": 1611724431862,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "lbT636mQOoY7",
    "outputId": "125f6791-d697-4d38-9694-c035cce58617"
   },
   "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": {
      "text/plain": [
       "(-2.5, 2.5)"
      ]
     },
     "execution_count": 21,
     "metadata": {
      "tags": []
     },
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 315x315 with 1 Axes>"
      ]
     },
     "metadata": {
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.style.use('default')\n",
    "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(samples[:,0][::split_][warm_sample:], samples[:,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.png\")\n",
    "# plt.close()"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyMaU0QM7ZD4Q2LjaN5chjt6",
   "name": "replica_exchange_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
}
