{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 19898,
     "status": "ok",
     "timestamp": 1611608063727,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "GPvl93lAgBwV",
    "outputId": "75f50b05-3203-4a3e-ecdc-7edec105b927"
   },
   "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",
    "from scipy.spatial.distance import pdist, squareform\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": 283,
     "status": "ok",
     "timestamp": 1611608072581,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "VGbs6GvcgINv"
   },
   "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": 357,
     "status": "ok",
     "timestamp": 1611608073330,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "JNQhUl6qgJ2g"
   },
   "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",
    "\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": "AKt2J-8zgL-K"
   },
   "source": [
    "# Build our sampler"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "executionInfo": {
     "elapsed": 273,
     "status": "ok",
     "timestamp": 1611608075837,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "yD6QaYeXgNvN"
   },
   "outputs": [],
   "source": [
    "class Sampler:\n",
    "    def __init__(self, f=None, dim = 2, xinit=None, lr=1e-3, T = 1, alpha = 0.9, debug = False):\n",
    "        self.f = f\n",
    "        self.lr = lr\n",
    "        self.debug = debug\n",
    "        self.alpha = alpha\n",
    "        self.historical_grad = 0\n",
    "        self.T = T\n",
    "        self.dim = dim\n",
    "      \n",
    "         \n",
    "        # initialization for SGLD\n",
    "        self.x = np.array(xinit)\n",
    "        \n",
    "    def svgd_kernel(self, theta, h = -1):\n",
    "        sq_dist = pdist(theta)\n",
    "        pairwise_dists = squareform(sq_dist)**2\n",
    "        if h < 0: # if h < 0, using median trick\n",
    "            h = np.median(pairwise_dists)  \n",
    "            h = np.sqrt(0.5 * h / np.log(theta.shape[0]+1))\n",
    "\n",
    "        # compute the rbf kernel\n",
    "        Kxy = np.exp( -pairwise_dists / h**2 / 2)\n",
    "\n",
    "        dxkxy = -np.matmul(Kxy, theta)\n",
    "        sumkxy = np.sum(Kxy, axis=1)\n",
    "        for i in range(theta.shape[1]):\n",
    "            dxkxy[:, i] = dxkxy[:,i] + np.multiply(theta[:,i],sumkxy)\n",
    "        dxkxy = dxkxy / (h**2)\n",
    "        return (Kxy, dxkxy)\n",
    "    \n",
    "    def grad(self, beta):  return grad(self.f)(beta)\n",
    "\n",
    "    def spos_step(self, iter):  \n",
    "        # Check input\n",
    "        if self.x is None or self.f is None:\n",
    "            raise ValueError('x0 or lnprob cannot be None!')\n",
    "        \n",
    "        # adagrad with momentum\n",
    "        fudge_factor = 1e-6\n",
    "        if self.debug and (iter+1) % 1000 == 0:\n",
    "            print('iter ' + str(iter+1))\n",
    "        \n",
    "        lnpgrad = np.array([self.grad(self.x[i]) for i in range(self.x.shape[0])])\n",
    "        \n",
    "        # calculating the kernel matrix\n",
    "        kxy, dxkxy = self.svgd_kernel(self.x, h = -1)  \n",
    "        grad_x = (-np.matmul(kxy, lnpgrad) + dxkxy) / self.x.shape[0]  \n",
    "        \n",
    "        # # adagrad \n",
    "        # if iter == 0:\n",
    "        #     self.historical_grad = self.historical_grad + grad_x ** 2\n",
    "        # else:\n",
    "        #     self.historical_grad = self.alpha * self.historical_grad + (1 - self.alpha) * (grad_x ** 2)\n",
    "        # adj_grad = np.divide(grad_x, fudge_factor+np.sqrt(self.historical_grad))\n",
    "        \n",
    "        self.x += self.lr * (grad_x - self.T * lnpgrad) + np.sqrt(2. * self.lr * self.T) * normal(size=(self.x.shape[0], self.dim)) \n",
    "     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 253,
     "status": "ok",
     "timestamp": 1611608092144,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "8b67oO6KZD-x"
   },
   "outputs": [],
   "source": [
    "xinit = np.random.uniform([lower, lower], [upper, upper], [500, 2])\n",
    "sampler = Sampler(f=mixture, dim=2, xinit=xinit, lr=3e-3, alpha = 0.9)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "executionInfo": {
     "elapsed": 347,
     "status": "ok",
     "timestamp": 1611608773823,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "OSbaagsSZGfT"
   },
   "outputs": [],
   "source": [
    "warm_up = -1\n",
    "spos_x = np.array([sampler.x])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1JjMD2POt0Kknsy_Ln7uiBNluzt0xQh_S"
    },
    "executionInfo": {
     "elapsed": 23648389,
     "status": "ok",
     "timestamp": 1611632426172,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "i5Sciv0tZIDf",
    "outputId": "9825af43-fd2e-4f2c-c183-6eb3000b117c"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Output hidden; open in https://colab.research.google.com to view."
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "my_images3 = []\n",
    "spos_x_path = []\n",
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/SPOS_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(5e4)):\n",
    "    sampler.spos_step(iters)\n",
    "    if iters > warm_up:\n",
    "        spos_x_path.append(sampler.x)\n",
    "        if iters % 1000 == 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(sampler.x[:,0], sampler.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",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'single_SPOS_contour_'+str(sampler.lr)+'.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 + 'single_SPOS_samples.txt', 'wb')\n",
    "pickle.dump(spos_x_path, f)\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 1732,
     "status": "ok",
     "timestamp": 1611634044242,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "-B_Xg5D4o5eH",
    "outputId": "607d77c0-fb55-436f-b129-1a358740405a"
   },
   "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": "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\n",
      "text/plain": [
       "<Figure size 540x226.8 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/'\n",
    "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 = 0\n",
    "split_ = 1\n",
    "spos_x = spos_x.reshape(-1,2)\n",
    "plt.subplot(1, 2, 2).set_title('(b) SPOS')\n",
    "ax = sns.kdeplot(sampler.x[:,0], sampler.x[:,1],  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/SPOS.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 307
    },
    "executionInfo": {
     "elapsed": 1152,
     "status": "ok",
     "timestamp": 1611634223051,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "usxs0OET4j8Y",
    "outputId": "2045e164-8be0-428a-97b3-62b57ba2e987"
   },
   "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": "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\n",
      "text/plain": [
       "<Figure size 226.8x226.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "PATH = 'anonymous/Contour-Stochastic-Gradient-Langevin-Dynamics/'\n",
    "fig = plt.figure(figsize=(3.15, 3.15))\n",
    "\n",
    "warm_sample = 0\n",
    "split_ = 1\n",
    "spos_x = spos_x.reshape(-1,2)\n",
    "plt.subplot(1, 1, 1)\n",
    "ax = sns.kdeplot(sampler.x[:,0], sampler.x[:,1],  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/SPOS.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 265
    },
    "executionInfo": {
     "elapsed": 3531,
     "status": "ok",
     "timestamp": 1611632429797,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "R_LKSulaxKrW",
    "outputId": "486e9933-9b14-46de-c440-1c36f16900d0"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQMAAAD4CAYAAADo84OlAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAdoElEQVR4nO2de5AV1Z3HvyczPGoGiDKCVokIcdFEpoZZmPCYFSFoUDOWgY3rxXGpS62UtVVOBbJJVgxJVapSa4JkfMS2ItadzbIVs87GR3ZXs0FNYJ2kYGuGlBKCCCOCzubKYzDsvZhhZ4bf/sHta9PTr3tvd59z+v4+VV0z9/btPr9z+pzv+f3O6e4jiAgMwzCfkG0AwzBqwGLAMAwAFgOGYQqwGDAMA4DFgGGYArUyEr3sssto1qxZMpJmmKpm7969p4homtM+KWIwa9Ys9PX1yUiaYaoaIcQxt30cJjAMA4DFgGGYAiwGDMMAkDRm4MTw8DAGBgYwNDQk2xQmJCZOnIgZM2Zg3Lhxsk1hAqCMGAwMDGDy5MmYNWsWhBCyzWEqhIgwODiIgYEBzJ49W7Y5TACUCROGhobQ0NDAQpAQhBBoaGhgT08jlBEDACwECYOvp14oJQYMw8iDxcDCpEmTAABHjx7FT37yk1DP/dBDD130ubW1tfj/6OgoTp48idHR0VDT7O3tRW1tLZ577rnidw888AAaGxvR2NiI7u7u4ve/+tWvMH/+fDQ2NiKdTmNkZAQA8OGHH2L16tVoamrCwoULsX///uIxjz/+OBobGzF37lw89thjFeUjn8+jq6sL+Xy+ghyHf66qgohi3xYsWEB2Dhw4MOa7uKmvryciop07d1JbW1tJxw4PDwc6txMnTpyg3t5eOnHiRElpejEyMkKf+9zn6LbbbqOf/vSnRET00ksv0c0330zDw8OUz+eppaWFzpw5Q6OjozRjxgx6++23iYjoW9/6FmUyGSIi+trXvkbf/va3iYho//79tHTpUhoZGaHf/e53NHfuXDp79iwNDw/TTTfdRHv27BmTj6DXNZPJEIBiupUQ5rmSBoA+cmmX7Bk4sGnTJvT09KC5uRmPPvooRkdH8fWvfx2f/exn0dTUhG3btgEAdu3ahaVLl+KOO+7A9ddfDwBYtWoVFixYgLlz5+Lpp58unu9Pf/oTmpubcc899wD42AshInzve9/D2rVrsWLFimJvvWvXLixfvhx33nknPv3pT+Oee+4BlfBWqieeeAJf+tKXMH369OJ3Bw4cwI033oja2lrU19ejqakJv/jFLzA4OIjx48fj2muvBQB8/vOfx/PPP188ZsWKFQCA6dOn48iRIzh48CDeeustLFq0CHV1daitrcWyZcuwc+dOXH311Zg6dWrJZZ5KpZDJZJBKpUo+NspzVRVuKhHlpptnsG3bNvrOd75DRERDQ0O0YMECOnLkCO3cuZPq6uroyJEjxd8ODg4SEdFHH31Ec+fOpVOnTl10bntazz33HN188800MjJCH3zwAV111VX0hz/8gXbu3ElTpkyh999/n0ZHR2nx4sXU09NDREQbN26kefPmjdm++93vEhHRwMAA3XjjjTQ6OkrpdLroGezYsYNaW1vp7NmzdPLkSZo9ezZ9//vfp/Pnz9PMmTOpt7eXiIi+/OUvU2NjIxERPfjgg7Rx40YiIvrNb35DNTU1tGfPHjpw4ADNmTOHTp06RWfPnqXFixdTR0fHmDJV4boyHwMPz0CZ+wzKIZ/Po7u7G6lUqtjTRsErr7yCffv2FWPvM2fO4PDhwxg/fjwWLlx40Tz6D37wA7z44osAgPfffx+HDx9GQ0NDcf/o6ChOnz5d/PzrX/8ad999N2pqanD55Zdj2bJl6O3txZQpU7Bw4ULMmDEDANDc3IyjR4/ihhtuwKOPPupp78aNG7FlyxZ84hMXO34rV65Eb28vWltbMW3aNCxZsgQ1NTUQQuDZZ5/FV77yFZw7dw4rV65ETU0NgAtezYYNG9Dc3IzZs2fj2muvxalTp9DS0oIHHngAK1euRH19PZqbm4vHMHqitRh0d3dj/fr1AIB77703snSICE888QRuueWWi77ftWsX6uvrL/r82muvYffu3airq8Py5cvHzLOfPn0ax44dC+TyT5gwofh/TU1NcVBvw4YN+OUvf4na2osv35o1a7Bp0yb09fVhzZo1AIBTp07h5z//OWpra7Fq1Sps3rwZmzdvBgC0t7cXQ4MlS5agp6cHwAXxO3ToEACgvr4eDz/8MIgIx44dw6pVq1BfX4/BwUHce++9xXL/xje+URQulYmrAykFVWzSWgzMmDDs2HDy5MnI5XLFz7fccgt++MMfYsWKFRg3bhwOHTqEK6+8csxxZ86cwaWXXoq6ujocPHgQe/bsKe4bN24choeHi/G0OQe/dOlSbNu2Del0GqdPn8brr7+OrVu34uDBg672ffOb38TatWtx9dVXY9q0sY+mv/vuu8X/161bh9tvvx2rVq3C6Ogo/vjHP6KhoQH79u3Dvn37sHLlSgDAiRMnMH36dJw7dw5btmwpCsa7776LkydP4pprrkFPTw9aW1uLFdY85r333sMLL7xwUX5VwtrY4upASkEVm7QWg0mTJkVSeE1NTaipqcG8efOwbt06bNiwAUePHsX8+fNBRJg2bRp+9rOfjTnu1ltvxVNPPYXPfOYzuO6667B48eLivvvuuw9NTU2YP38+nnnmmeL3q1evxu7duzFv3jwIIfDwww/jiiuu8BQDU1BKHagbHh7G0qVLAQBTpkzBj3/846J3sXXrVrz00ks4f/481q5di2XLlgEAPvjgA6TTadTU1GDOnDn40Y9+BCEEpk6diuXLl2NwcBDjxo3Dk08+iUsuuaQke8LEq3e1NraoOpBKUMYmt8GEKLc4BhBHRkboxIkTNDIyEup5k47bNOfx48ept7eXjh8/ftH3fuUc1wCi13RiLpejTCZDuVzO8Vi//UkCUQ4gCiGuAvDPAC4HQACeJqLHKz1vpZixOQBHV1o25kDi1KlTlRp4K9XrsI6BmB6DjPx49a5+HqQqbrpswggTRgB8lYh+K4SYDGCvEOJVIjoQwrkBlNdwynWlo8DJflXFqqamxtEe8yEyszzNPJmhARUGGIH48xNkAM7rN8q46ZKp+KYjIsoS0W8L/+cAvAVg7OhasHM5fm82HOuUnN+tr2alVqHXdbJ/6tSpnjfoRHWLcrnYy9PM04cffggAuPTSS8fkx+16ho3Zs1tvrw76G1VG8k1b3G6jjuUWa7f4oZwNwCwA7wGY4rDvPgB9APpmzpw5JpY5cuQInTx5ks6fPz9m38jICB0/fpyOHz9ejE2juIU3KuxxtVOcbf9O9fyZ9ppjCaad5vfnzp2jd955hw4fPhyZDWasn81mfWN+t3EBlW5dNm1Jp9OR2QmPMQNBIam3EGISgP8C8A9E9ILXb1taWsj+dmS/Nx3l83kMDg6ioaEBkyZNwvnz5/HRRx+hrq5uzM01sghqkz0vTt/Jzl/Q9O2/M/NRV1eHN954A5/85CeRTqcjsbGrqwvr169HJpMpO9a3egYApHoJ+XweHR0d2L59+5g8heXBCCH2ElGL4043lShlAzAOwA4Afxfk906zCX7oMOIbVL2d8pLNZimdTlM2m43azECU2xOV0ltXiludKLeuqOAlRF3P4eEZhCEEAhdmEx4Lekw5YqADXhfS7yKrUBGt6CC+blQqZDrmOShRi8ENuDCluA/AG4XtC17HJFUMvPCroLpURCc7VbNdNXtUIlIxKGerRjFISgV1EjXVvBrGHS8x0Pp25CCoMnUU1a3TceM0Jx/mPL0q16sqcVOJKLc4PQOdeq2keA+VoNP10hEk0TMI2oPodHcZ3xar1/VKGtqKQdCGo5N7zg1Br+uVNLQVA90bjpNnww2BkYkat+6VgdlwdB1kcrpXnl/xzchEW89Ad5w8Gx4zYGTCYiAJp5BA99CnWknKdKi2YUIS0T30qVaCPEKtA+wZMEyFJMWjY89AAXjgUG/C9Ohk1gUWAwVIipvJVI7MusBhggIkxc1kKkdmXQjtTUel4PSmI4ZhosfrTUccJjAMA4DFgGGYAiwGDMMAYDFgGKYAiwHDMABYDBiGKcBiwDAMABYDhmEKsBgwDAOAxYCpEvhhMH9YDJiqgB8G84cfVJJMUt6Sozr8MJg/7BlIhnuseNDtLVIywhr2DCTDPRbjhIyX41aFZyBr8ChIuvYeS7WBLi97VLM1SaRSKWQymXg7Cbd116Lc4l6FWdb6feWkq9pag172qGYr4w+SuNZiKchyxc302tra0NXV5TpIaB1EVClsyOfzGBoagmEYjvaoZCsTAm4qEeXm5hlEsQqx9ZyyVjn260H99su2O51OUzabrfoVopMAdPEMohg0sZ4TgJQVi/x6ULf9pscwNDSEjo4OAPHb3dPTg+3btwMAtm/fjqGhIUycOJGnQpOIm0pEuVWbZ+Bll1ePa/bMhmFIs9tqp2EY1N7ezuMEGgMPz0ApMagUlRq7H1YX3PxrtzubzRZddBWw2qx6GQepCzLqi+w6WjViEHR0O84L4paWtcc1BcFud9yj9X7lEsSbkYGT3U5lZ/+djNkQ2TMwVSMGuVyODMMgwzA8K2ocF8SseIZhXJSWk41+ghFXo3MLS1RoRF5Y7fESLLvd7BkkWAyIglXUOC6IW8Myv1epMZm4CZgKjcgLqz1etqpit8wQpqrEQPULbvUMzEG5zs5OX28marwajVNva/dwgoYYUedRdS+GKJhNUdmtvRg4VST7KLfsxlQOVi9BdoUttYLaPZxK76WIClVEKmiaUY/LaC8GTq6fOehmTnXJbkzlYPauqnkGfr+xezRBBFm1QVu3sEI2UdujvRi4uX7pdJo6OzuLoqCyZ6BiD1Uu9gqrS4OyT+daBUF2ucc1U5M4MVBxUMiOm4C53UDkt18GbuFZ0NkQWZTiGaiC04xIFPZpLwaq9TxBcBvVto/Um/jtl4Fpi2EYxe90vBaqiZUTXjMiYeIlBko9m+CGjk/H2W0231uQz+eL9/Zb8duvCjpeC/P5FJWfqzCvPyCvjMUFsYiXlpYW6uvriz1dFdDpnYc62eqF/YGvTCYT6wNfKiGE2EtELY473VyGKLe4X26iEm7hg4pxbJio4KqrYINsoPuYQZLwmhmB4rF4JY1Jx7GGJJIYMUiissvyDMopy0oadBKvnY4kRgy4dwmPcsqSG7T+eImBFrMJJjqOZKtKOWVpHfFmkgfPJjBMFeE1m1AV6yYwDOMPiwHDMABYDBiGKcBiwDAMABYDhmEKsBgwDAOAxYBhmAIsBgzDAGAxYBjtyefz6OrqQj6fr+g8LAYMoznmy1u6u7srOo9WzyYwTKUk5YUtVsJ6Zoc9A6aqCKsXVQnzAbJKxY09A8aTpPWk/OSrO+wZMJ4krScNqxdNIuwZMJ5wT1o9sGcQI2FNAcUJ96TRoVp9YDGIER1dbtUqbJJQrT5wmBAjpbjcqgzcmRUWAL/yLGSUC8HcXo4Y5VbNr0oPiiovf+WXoKpBWNcBHi9E5TAhRkpxuVOpFDKZTGy9hpttSRkz0D3ciSWkcFOJKLcoPQOVezJVensnyrVNZnmXkraKZV+K/XF4BokTAxUvuonKQlWubTLLu5S0g+YvzmvkZX9UdlSVGKh40VUWASdyuRwZhkGGYVxks9P3ungGQYlD3IKsomUYBgEgwzBCTTsxYlDqxff6fZgX3c8ua1rW39qPU0U0THvt5eP2vRU3IfFClXzHZUuQuhdEDMqxNTFiUGoDjssN87PLmpb1t/bjVAlx7A3a2pOZ37v1ak6CUYpYBrEt7jg7bIJ0AkFEtZz6khgxCNMzCJNyK6iqnoEdp0pnXT3arxKXIpZBbTHTjcv7ixI3O93K2ERJzwDArQDeBtAPYJPf76v5PgN7vGj/q5oQELmPFQRdRj5MkbOn6+ROm+n19/dTOp2mbDYb6LyqjX3Y8xqGjZGKAYAaAO8A+BSA8QDeBHC91zHVJgZOYYJ5ke1/4+rFSq1YTr2XrAZkTddJDOxlHKRM4/QiyvUkw7AxajFYAmCH5fODAB70OqbaxMA+gGgYBnV2dhY3rxg8DpuC4BTeWG1WQRjs35VSprKnFHO5HHV2dlJ7eztls1nPfKnsGdwJIGP5vBaA4fC7+wD0AeibOXNm2ZnxQ8W4296Q3LyBckbiw7CpFNutrrnVfr/4ViXKEYso0remax14bW9vj8xTUUIMrFuYnoG9YOOaQSgX077W1lbq7+93tF3WoJdTI3Ga/TAMY8x4h2EY1N7eHtpAYaVks1lKp9PU39/vOqDpFEbI9HDuuusuAkCdnZ2R2ZHoMMHe+L1UX0ZcaB8g7O/vp9bWVkc74vQMnHBqJF6zH/bjTJEIcyqsXMw8mGVtHVdQpY7YiUOIohaDWgBHAMy2DCDO9TomSs/ARPaAl9tAoVk5VXSny3Wfywk5osb0DN58801atGhRscf1E1sVp6PDJI6pxS8AOFSYVdjs9/s4BhBlhwROnoFVGMIeGFIF1fJiFeXOzk6pYZiTXaY4uQlU2AOJibnpSEfc3Oywp4xUQYW8uJWzOfDZ3t4uXaxMu/wEyqk8KyljrcRAtZ6lUtziaft0Y1LyrEJe3BqLCrbZ8RMovyndUtFKDFToWcLEPh1nH+hUqWImAb9BWNXKvRR7wmgbWomBahcrLHTLV6X2ysqvX4NRrbMppZyUv+monE3GmIFKjVElW9yotNHIanR+ZWvfL/taxF1OLAakVo+gki1u6OoZlGqL7GsRdzmxGJA+lbOc3zHeeDX4sKfuVIfFQFN0uxtOhUYUtHGr7C1ESVWJgQoVMixk5qWcBqFCIwpqQ6neQlKoKjFQoUImgSR5BpX8Lml4iYG4sD9eWlpaqK+vL5Jzq7IsGcOoiBBiLxG1OO1L3FqL5gpADMOUBi+vxjAMABYDhmEKsBgwDAOAxYBhmAIsBgzDAGAxYBimAIsBwzAAWAwYhinAYsAwDAAWA6ZKyefz6OrqQj6fl22KMrAYMFVJd3c31q9fj+7ubtmmKEPink1gmCCkUqmL/jLsGTAeJNmVNh9o4ydbP4bFgHGFXenqgsWAcaWtrQ3pdBptbW2yTWFigMVAMnZXXCXX/OWXX8b27dvx8ssvyzal6pBRDxIlBio1pKDYXXGVXPNUKoVMJoO2tjbfctWx7FUmrHpQ0nVxex9alFtU70DU8f2Hqi3q4USQclW17FUszyCEZbf9uqBaXoiq64VXnSDlqmrZqypScWG/LlUjBlZUrZy6o1u5yrRXxbLyEoNEjRlYUSn2Tgr5fB4dHR1KlatfTOx3P0GUYx0y6mBF+XFTiSi3Sj0D3dxWqy0q2eVEkJWG0uk0ZbNZJfJRSRiQy+UonU4X8xR2XmTUU7/yQNLCBNXjQPsFttprGAYBIMMwJFvpTNCVhlS5BpU0JjMPra2tkefFzc6wy9GvPBIlBrlcjgzDIMMwAi+7HTf2C2y1R3Ux0H1FIq/ZGbd9cXg5bo0+m80WPa04SJQY6DDN5dVQZDeiUtMPsmip7DxZsYut9bOKC9nGbVOixEC38QLVKKXyWWNqa3hgNjDzHHFXaK/r6yUGKopY3DYkSgySQpBwJ6p0g1Y+64ChdZzA7GVlNapSVlCu1qXX3ahaMVBZ+c2K6FQZVbDbyQ4/u+KyO0joUu55kk7VioEKyu9mg+kZdHZ2jvEOVLDbC1XiX1XS1omqEQNdYkLrKLY1Jvc6Jm68ytJL4Phuv9KJ0/aqEQNdegdrLB7VDS+VYi9L62cdG57KMzxx1tuqEQPZFzUopp27d++ma665ht58803ZJo2hlPl6Fezzw6vBye5E4rzXINFioELFLBfzzrfW1tYx+1TOl9dNVbJs8MMvXGPPIAFi4FSQKjSkICPvDz30EC1atIj6+/vH7JfdW3lhz5sMW8OYUVAl9OExg5BwKkgVGpKfDX77VRC0oKhia6mNO8igaNJItBg4oULlVGVOPmpUykcljVtmyMCeAUNEajWmUjDttt+arArllqsMD4HHDBgiUiduLRXTbvutyboj4xqwZ8AQkb5xq07CxXyMlxiIC/vjpaWlhfr6+mJPV3Xy+Ty6u7uRSqV42a8K4bJ0Rgixl4hanPYl9h2IOsLr/4UHvwOzdHgVZiaR8CrLpcOeAZNIkuBlxb1KFYsBwyhK3KEOhwkMoyhxhzrsGUiEFytlvIg71GExkAiPeDMqwWGCRHjEm1EJFgOJmG4gw6gAhwkMwwBgMWAYpgCLAcMwAFgMGIYpwGIQMXwvAaMLLAYRw/cSMLrAU4sRw/cSxA+/y6A82DOImCQ8Pacb7I2VB3sGTOJgb6w8WAyYxMF3dpYHhwkMwwBgMWACwNOj1QGLAeOLdUCOhSG5JE4MuLKGTyqVQiaTQSqVUm6k3u9661QfpNvqtqBClFuUi6jotBCJyrgtkqLa4imVLnCrEnHYimpaUUm1yqoLfsusl7qqcVxEtcCtinkJg6oSAxOdREGFFYDtC6jay8/c397e7mqf6r1wKXVCdl6iqr9VKQayL2YpmLam0+nANodRWXK5XDFNvwVUTTHwsi/MChx2Y7DmNa7yrYSo6m9kYgBgK4CDAPYBeBHAJUGOY8/gYsrxDMKoLFYR8kszl8uRYRhkGEYsZRp2YyglryqgnWcAYCWA2sL/WwBsCXIcr8JcOaVUlrgHA8PyWsL2DHTpHKIkljABwGoAzwT5rSwxUKFCyLChnF62Ejt1CtHiIgzxDoO4xOA/APy1x/77APQB6Js5c2bomQyCCpVUhg3lVK5KBETGQKjq+M3OWD9HWUcqEgMArwHY77B90fKbzYUxA+F3PmLPQLoNQYhLQMpBlzK04jd1a/2srWcAYB2A3QDqgh5T7WMGOlbmIMSVLxU8vErx8gyiJMoBxFsBHAAwrZTjql0MklCZ3YijUpeTRlIFuFS8xKDS9xkYACYAeFUIAQB7iOhvKzxn4kmlUhgaGsKZM2fwyCOPYMKECUin09q8DcnrtWLmswsAInunQDnvK4jDLt2pSAyI6M/CMqQSdHvn3aRJkzBx4kR0dHRc9P39998vyaLS8GpYqr5lSFW7lMLNZYhyCztMcHK7ZbuFQe6ZNwyD7rrrruIdgLogu2y9UNk2FUDSb0d2qgCy4/Kg6etWeVW3V/Z1V53Ei4ETsiut7PSjQvXGltRyDwsvMRAX9sdLS0sL9fX1xZ4uUzm6jc/oQJxlKoTYS0QtTvsS96Yj3ZD+dpsS4XUgwkeVt0dpJwa6NR4/VKkIjDysr5UrlTDbg3brJiRtvpinvJhK1nkIsz1oJwZJazy84Ed1U+l4QZjtQTsx4MbDJIlKe/Yw24N2YsAwSUIlT5fFgGEkopKnq91sgk4kbeaDSTYsBhHC04aMTnCYECEqxYMM4weLQYSoFA8yjB8cJjAMAwByHlQSQpwEcCyCU18G4FQE540Stjl6dLMXiM7mq4lomtMOKWIQFUKIPrcnslSFbY4e3ewF5NjMYQLDMABYDBiGKZA0MXhatgFlwDZHj272AhJsTtSYAcMw5ZM0z4BhmDJhMWAYBkACxUAIsVUIcVAIsU8I8aIQ4hLZNvkhhPgrIcTvhRDnhRDKToEJIW4VQrwthOgXQmySbY8fQoh/FEKcEELsl21LEIQQVwkhdgohDhTqw4Y400+cGAB4FUAjETUBOATgQcn2BGE/gL8E8LpsQ9wQQtQAeBLAbQCuB3C3EOJ6uVb58k+4sB6oLowA+CoRXQ9gMYD74yzjxIkBEb1CRCOFj3sAzJBpTxCI6C0ielu2HT4sBNBPREeI6P8APAvgi5Jt8oSIXgdwWrYdQSGiLBH9tvB/DsBbAK6MK/3EiYGNvwHwn7KNSAhXAnjf8nkAMVbUakMIMQvAnwP477jS1PKpRSHEawCucNi1mYj+rfCbzbjgdj0Tp21uBLGZYQBACDEJwPMANhLR/8aVrpZiQEQ3e+0XQqwDcDuAm0iRGyn8bNaA/wFwleXzjMJ3TIgIIcbhghA8Q0QvxJl24sIEIcStAP4ewB1E9JFsexJEL4A5QojZQojxANYA+HfJNiUKIYQA0AXgLSJ6JO70EycGAAwAkwG8KoR4QwjxlGyD/BBCrBZCDABYAuBlIcQO2TbZKQzKdgDYgQsDW/9KRL+Xa5U3Qoh/AbAbwHVCiAEhhOpvmvkLAGsBrCjU3TeEEF+IK3G+HZlhGADJ9AwYhikDFgOGYQCwGDAMU4DFgGEYACwGDMMUYDFgGAYAiwHDMAX+HwQIoEV1kkgmAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light",
      "tags": []
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig3 = plt.figure(figsize=(4, 4))\n",
    "plt.yticks([-4, -2, 0, 2, 4]) \n",
    "plt.scatter(sampler.x[:,0], sampler.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",
    "fig3.savefig( PATH + \"samples.png\")\n",
    "plt.close('all')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "zmJymjmgmh1_"
   },
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "FJ0uxAB_uhCX"
   },
   "source": [
    "# Build Parallel Sampler\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "bqxhNFkqgzmD"
   },
   "outputs": [],
   "source": [
    "psampler = []\n",
    "for i in range(5):\n",
    "    xinit = np.random.uniform([lower, lower], [upper, upper], [100, 2])\n",
    "    psampler.append(Sampler(f=mixture, xinit=xinit, lr=3e-3, alpha = 0.9))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "Hdh__iZ-mvlM"
   },
   "outputs": [],
   "source": [
    "warm_up = -1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 1000,
     "output_embedded_package_id": "1qXOMJQ2H6YzvY7XWesiNyK-no8I0t-Rw"
    },
    "executionInfo": {
     "elapsed": 123428,
     "status": "error",
     "timestamp": 1610510906334,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "rzfKZMLuuqL6",
    "outputId": "3afcb20f-552a-49a9-916c-e2fc5a08bf2f"
   },
   "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/SPOS_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",
    "spos_x_path = []\n",
    "for iters in range(int(1e4)):\n",
    "    for i in range(5):\n",
    "      psampler[i].spos_step(iters)\n",
    "    if iters > warm_up:\n",
    "        # save the sampels\n",
    "        spos_x_path.append(np.array([psampler[i].x for i in range(5)]).reshape((-1,2)))\n",
    "        if iters % 10 == 0:\n",
    "            spos_x = np.array([psampler[i].x for i in range(5)]).reshape((-1,2))\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(spos_x[:,0], spos_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",
    "          \n",
    "\n",
    "imageio.mimsave(PATH+'population_SPOS_contour_'+str(psampler[0].lr)+'.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_SPOS_samples.txt', 'wb')\n",
    "pickle.dump(spos_x_path, f)\n",
    "f.close()            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 323
    },
    "executionInfo": {
     "elapsed": 1742,
     "status": "ok",
     "timestamp": 1610512420036,
     "user": {
      "displayName": "YUBO WANG",
      "photoUrl": "",
      "userId": "04037309235043616004"
     },
     "user_tz": 300
    },
    "id": "aBqp3tkavBt9",
    "outputId": "9779be17-274f-4431-d94a-e81a75045733"
   },
   "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": "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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",
    "spos_x = spos_x.reshape(-1,2)\n",
    "plt.subplot(1, 2, 2).set_title('(b) SPOS')\n",
    "ax = sns.kdeplot(spos_x[:,0], spos_x[:,1],  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_SPOS_\"+str(psampler[0].lr)+\".png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "WD2tPA8JvyLk"
   },
   "outputs": [],
   "source": [
    "spos_x = np.array([psampler[i].x for i in range(5)]).reshape((-1,2))\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(spos_x[:,0], spos_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",
    "fig3.savefig(PATH + \"samples.png\")\n",
    "plt.close('all')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "lwQ0jvvlPpcx"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "authorship_tag": "ABX9TyPz2hb5EJiKvr6JflzTG4u0",
   "name": "SPOS.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
}
