{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c1d6620b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def gauss(_r, r0, sigma):\n",
    "    return np.exp(-(_r-r0)**2/(2*sigma**2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "eb4b9518",
   "metadata": {},
   "outputs": [],
   "source": [
    "def potential(x,y):\n",
    "    x = 2*np.pi*x  - np.pi\n",
    "    y = 2*np.pi*y - np.pi\n",
    "    cx = 0.0\n",
    "    cy = 0.0\n",
    "    r = np.sqrt((x-cx)**2 + (y-cy)**2)\n",
    "    sigma = 0.06\n",
    "    return -np.log(gauss(r, 1.0, sigma) + 0.8 * gauss(r, 2.0, sigma) + 0.6 * gauss(r, 1.5, sigma) + 0.4 * gauss(r, 2.5, sigma))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "13959022",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "from matplotlib.colors import LogNorm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "55c7269b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "X, Y = np.meshgrid(np.linspace(0,1, 100), np.linspace(0,1, 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "265ac8e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 1.0)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "cs = plt.contour(X,Y,potential(X,Y))#, levels=[0,1,3,5,30])#, norm = LogNorm())\n",
    "plt.clabel(cs)\n",
    "plt.xlim(0,1)\n",
    "plt.ylim(0,1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a96f7cd2",
   "metadata": {},
   "source": [
    "## Sample"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "efe7ca27",
   "metadata": {},
   "outputs": [],
   "source": [
    "x0 = np.column_stack([X.flatten(),Y.flatten()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "ac650a3d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000, 2)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x0.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cd2255a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "#plt.scatter(x0[...,0], x0[...,1], s=0.01)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3a64dfc9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def enforce_boundaries(x):\n",
    "    x[x[...,0]>1,0] = 2-x[x[...,0]>1,0]\n",
    "    x[x[...,0]<0,0] = -x[x[...,0]<0,0]\n",
    "    x[x[...,1]>1,1] = x[x[...,1]>1,1] - 1 \n",
    "    x[x[...,1]<0,1] = 1+x[x[...,1]<0,1]\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "855492f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def mcmc(x=x0, f=potential, sigma=0.1):\n",
    "    u = potential(x[...,0],x[...,1])\n",
    "    # proposal\n",
    "    std = sigma*np.random.randn(*x.shape)\n",
    "    x_ = enforce_boundaries(x + std)\n",
    "    u_ = potential(x_[...,0], x_[...,1])\n",
    "    # acceptance\n",
    "    alpha = np.exp(-(u_-u))\n",
    "    acc = (np.random.rand(x.shape[0]) <= alpha) | (u_ < u)\n",
    "    x = np.where(acc[...,None], x_, x)\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b2834454",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = mcmc(x0.copy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "badec7a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# equilibrate\n",
    "for i in range(1000):\n",
    "    x = mcmc(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "178f9f60",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(4, 4))\n",
    "plt.hist2d(x[...,0], x[...,1], norm=None, bins=100);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e3770c77",
   "metadata": {},
   "outputs": [],
   "source": [
    "# production\n",
    "data = []\n",
    "for i in range(10):\n",
    "    x = mcmc(x)\n",
    "    data.append(x.copy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "23c0d1d6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(100000, 2)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = np.concatenate(data)\n",
    "data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "3179e8f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"2dsamples.npy\", data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1cca923a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "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.9.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
