{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "859467ed",
   "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": "83d08df9",
   "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",
    "    dx = np.cos((x - cx)**2 / 2) + 1\n",
    "    dy = np.cos((y-cy)**2 / 2) + 1\n",
    "    r = np.sqrt(dx + dy)\n",
    "    sigma = 0.05\n",
    "    p = 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)\n",
    "    \n",
    "    return -np.log(p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d2ef0fdd",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib import pyplot as plt\n",
    "from matplotlib.colors import LogNorm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "8dde3f24",
   "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": "a63b7721",
   "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": "f66d638e",
   "metadata": {},
   "source": [
    "## Sample"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9414e9db",
   "metadata": {},
   "outputs": [],
   "source": [
    "x0 = np.column_stack([X.flatten(),Y.flatten()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "840a16ca",
   "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": "40a27bed",
   "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": 9,
   "id": "dd04d7c5",
   "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": 10,
   "id": "72de0567",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = mcmc(x0.copy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d19546b0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# equilibrate\n",
    "for i in range(1000):\n",
    "    x = mcmc(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "7125dde8",
   "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=LogNorm(), bins=100);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a1d3c690",
   "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": 14,
   "id": "ab442ac0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(100000, 2)"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = np.concatenate(data)\n",
    "data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "774ed258",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"2dsamples-periodic.npy\", data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "69cd2b54",
   "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
}
