{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "695715d0",
   "metadata": {},
   "source": [
    "# Two Gaussians Test\n",
    "\n",
    "Test of Hamiltonian Nested Sampling on a mixture of two Gaussians"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "480d0b81",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/pablo/miniconda3/envs/gns/lib/python3.10/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "# Imports\n",
    "import numpy as np\n",
    "import torch\n",
    "from gradNS import Param, NestedSampler, EllipsoidalNS, SliceNS, DynamicNestedSampler, HamiltonianNS\n",
    "from getdist import plots, MCSamples\n",
    "import time\n",
    "\n",
    "# --- plotting --- \n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "#mpl.rcParams['text.usetex'] = True\n",
    "mpl.rcParams['font.family'] = 'serif'\n",
    "mpl.rcParams['font.size'] = 10\n",
    "mpl.rcParams['axes.linewidth'] = 1.5\n",
    "#mpl.rcParams['axes.xmargin'] = 1\n",
    "mpl.rcParams['xtick.labelsize'] = 'x-large'\n",
    "mpl.rcParams['xtick.major.size'] = 5\n",
    "mpl.rcParams['xtick.major.width'] = 1.5\n",
    "mpl.rcParams['ytick.labelsize'] = 'x-large'\n",
    "mpl.rcParams['ytick.major.size'] = 5\n",
    "mpl.rcParams['ytick.major.width'] = 1.5\n",
    "mpl.rcParams['legend.frameon'] = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b6734adc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def sample_gaussian(ndims = 2, sampler = 'nested', sigma=0.):\n",
    "    #assert sampler in ['nested', 'multinest', 'polychord', 'gannest']\n",
    "    mvn = torch.distributions.MultivariateNormal(loc=torch.zeros(ndims),\n",
    "                                             scale_tril=torch.diag(\n",
    "                                                 torch.ones(ndims)))\n",
    "\n",
    "    \n",
    "    params = []\n",
    "    for i in range(ndims):\n",
    "        p = Param(\n",
    "                name=f'p{i}',\n",
    "                prior_type='Uniform',\n",
    "                prior=(-5, 5),\n",
    "                label=f'p_{i}')\n",
    "        params.append(p)\n",
    "        \n",
    "    if sampler == 'base':\n",
    "        ns = NestedSampler(\n",
    "            nlive=25 * ndims,\n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            clustering=False,\n",
    "            verbose=False)\n",
    "    elif sampler == 'ellipsoidal':\n",
    "        ns = EllipsoidalNS(\n",
    "            nlive=25 * ndims,\n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            eff=0.1,\n",
    "            clustering=False,\n",
    "            verbose=False)\n",
    "    elif sampler == 'slice':\n",
    "        ns = SliceNS(\n",
    "            nlive=25 * ndims,\n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            clustering=False,\n",
    "            verbose=False)\n",
    "    elif sampler == 'dynamic':\n",
    "        ns = DynamicNestedSampler(\n",
    "                    nlive=25 * ndims,\n",
    "                    loglike=mvn.log_prob,\n",
    "                    params=params,\n",
    "                    clustering=True,\n",
    "                    verbose=False)\n",
    "    elif sampler == 'hamiltonian':\n",
    "        ns = HamiltonianNS(\n",
    "            nlive=25 * ndims,\n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            sigma_vel=sigma,\n",
    "            min_reflections=1, \n",
    "            max_reflections=3,\n",
    "            clustering=False,\n",
    "            verbose=False)\n",
    "        \n",
    "    ns.run()\n",
    "    return ns.get_mean_logZ(), ns.get_var_logZ()**0.5, ns.get_like_evals()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f6722a2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "D = 10, logZ = -23.0259\n",
      "logZ = -23.0285 +/- 0.3725, like_evals = 475470, time = 4.6782\n",
      "D = 15, logZ = -34.5388\n",
      "logZ = -34.4490 +/- 0.4483, like_evals = 930549, time = 8.6764\n",
      "D = 20, logZ = -46.0517\n",
      "logZ = -46.3198 +/- 0.5005, like_evals = 1560144, time = 16.9706\n",
      "D = 25, logZ = -57.5646\n",
      "logZ = -57.7867 +/- 0.7100, like_evals = 2473861, time = 25.5335\n",
      "D = 30, logZ = -69.0776\n",
      "logZ = -69.3786 +/- 0.4584, like_evals = 3585096, time = 34.0310\n",
      "D = 35, logZ = -80.5905\n",
      "logZ = -80.8624 +/- 1.1272, like_evals = 5044805, time = 45.3585\n",
      "D = 40, logZ = -92.1034\n",
      "logZ = -92.2802 +/- 1.0084, like_evals = 6553350, time = 58.4179\n",
      "D = 45, logZ = -103.6163\n",
      "logZ = -103.9862 +/- 0.7494, like_evals = 8545803, time = 63.1663\n",
      "D = 50, logZ = -115.1293\n",
      "logZ = -115.8377 +/- 0.7354, like_evals = 10674042, time = 79.1458\n"
     ]
    }
   ],
   "source": [
    "dims = [10, 15, 20, 25, 30, 35, 40, 45, 50]\n",
    "logZ_true = np.zeros_like(dims, dtype=np.float32)\n",
    "\n",
    "logZ = np.zeros_like(dims, dtype=np.float32)\n",
    "err_logZ = np.zeros_like(dims, dtype=np.float32)\n",
    "like_evals = np.zeros_like(dims, dtype=np.int32)\n",
    "\n",
    "times = np.zeros_like(dims, dtype=np.float32)\n",
    "\n",
    "num_repeats = 10\n",
    "\n",
    "for i, d in enumerate(dims): \n",
    "    logZ_true[i] = np.log(1 / 10.**d)\n",
    "    print(f\"D = {d}, logZ = {logZ_true[i]:.4f}\")\n",
    "    \n",
    "    logZ_local = np.zeros(num_repeats, dtype=np.float32)\n",
    "    err_logZ_local = np.zeros(num_repeats, dtype=np.float32)\n",
    "    like_evals_local = np.zeros(num_repeats, dtype=np.int32)\n",
    "    times_local = np.zeros(num_repeats, dtype=np.float32)\n",
    "    for j in range(num_repeats):\n",
    "        start_time = time.time()\n",
    "        logZ_local[j], err_logZ_local[j], like_evals_local[j] = sample_gaussian(ndims = d, sampler = 'hamiltonian', sigma=0)\n",
    "        times_local[j] = time.time() - start_time\n",
    "        \n",
    "    logZ[i] = np.mean(logZ_local)\n",
    "    err_logZ[i] = np.std(logZ_local)\n",
    "    like_evals[i] = np.mean(like_evals_local)\n",
    "    times[i] = np.mean(times_local)\n",
    "    \n",
    "    \n",
    "    print(f\"logZ = {logZ[i]:.4f} +/- {err_logZ[i]:.4f}, like_evals = {like_evals[i]}, time = {times[i]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cd5ce9e0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x2a23f4a30>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 472.441x236.22 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_size=12\n",
    "y_size=6\n",
    "fontsize = 8\n",
    "fig, ax = plt.subplots(figsize=(x_size/2.54,y_size/2.54))\n",
    "ax.errorbar(dims, logZ - logZ_true, yerr=err_logZ, fmt='x', label='$\\sigma = 0$')\n",
    "#ax.errorbar(dims, logZ_sigma001 - logZ_true, yerr=err_logZ_sigma001, fmt='o', label='$\\sigma = 0.01$')\n",
    "#ax.errorbar(dims, logZ_sigma005 - logZ_true, yerr=err_logZ_sigma005, fmt='o', label='$\\sigma = 0.05$')\n",
    "ax.axhline(0, ls='--', color='k')\n",
    "#ax.set_yscale('log')\n",
    "#ax.set_xscale('log')\n",
    "ax.set_xlabel(\"# of Dimensions\", fontsize=fontsize)\n",
    "ax.set_ylabel(r\"$ \\log Z$\", fontsize=fontsize)\n",
    "ax.set_xticks(dims)\n",
    "ax.set_xticklabels(np.array(dims, dtype='str'), fontsize=fontsize)\n",
    "#ax.set_yticks([1e4, 1e5, 1e6, 1e7, 1e8])\n",
    "#ax.set_yticklabels(['$10^4$', '$10^5$', '$10^6$', '$10^7$', '$10^8$'], fontsize=fontsize)\n",
    "#ax.set_ylim(-0.5, 0.5)\n",
    "plt.legend(fontsize=fontsize)\n",
    "#plt.savefig(\"/Users/pablo/Desktop/ns_comparison\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "345ee0db",
   "metadata": {},
   "outputs": [],
   "source": [
    "dims_dynesty = [4, 8, 16, 32, 64]\n",
    "\n",
    "like_evals_dynesty = [4823,\n",
    "                     14894,\n",
    "                     264679,\n",
    "                     4963095,\n",
    "                     37631995,\n",
    "                     #258475046    \n",
    "]\n",
    "\n",
    "like_evals_hslice = [1435550,\n",
    "                    6731543,\n",
    "                    24780186,\n",
    "                    80007756,\n",
    "                    265605832,\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "38cf1186",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x2aa15e4a0>"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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amoqly5dqtDD7x8UERHBjBkzqF+/PhEREYwfP55+/foBcOHCBdauXcuqVat48803GTt2LD169DByxCWjqO+fF1988ZGfkfPnz/PJJ5/QuHFj4uPjqV69OqtWrcLCwkKve0rCE0IIUSnIMzwhhBCVgiQ8IYQQlYIkPCGEEJWCJDwhhBCVgiQ8IYQQlYIkPCGEEJWCJDwhinDx4kV69+4NQP/+/Tl16pTB18jMzGTo0KFMnz6d/v37a2sogmYOUt++fbG3t2fixImMHj2awYMH61TzURQFDw8PbbFcY7lw4QJdu3Y1agxCFAcpHi1EEf78809eeOEFMjMzuXLlCu3btzf4GgEBASQkJLB9+3bS09MxNzfX7uvWrRteXl6sXLmSlStXAhAbG0v//v2Jiopi2rRpqFQq9u3bh52dXbG9ryfRvHlzfH19jRqDEMVBWnhCFODj40PTpk357LPP+N///oe7uzupqal4enqybt26Qser1WpmzZrFe++9x7hx45gxYwa5ublERUWxaNEirl27xrhx4zh//rxOwitK3bp1+frrr5k9ezYZGRmsXr2anj17cvjwYe7cuUOnTp1wdXVl/vz5dOzYkQEDBuDn58fgwYNp3Lgxe/fu1V7r0KFDvPHGG3z88ceMHDmSq1evAjBgwABUKhVr1qyhT58+tG7dmvDwcADi4+MZMWIEH374IW+88Qb/93//B8CHH36Iu7u79toXLlzglVdeYfr06YwYMYIzZ84A8Omnn2Jtbc3cuXMZNGgQjRo1Ys+ePdqv0/jx45k4cSKTJk2qVJVnRBny9JXQhKh4HBwclKysLGXBggXK0qVLH3rc999/rwwaNEj7euTIkcq3336rKIqiHDp0SOnZs+dDz123bp3Srl07nW2JiYkKoJw6dUpRFE2twEOHDimKoqlRaWZmply9elVRFEXp2rWr8u677yqKolmRoEuXLoqiKEpCQoLi7OysXcHir7/+Ujp16qS9B6D8+eefiqIoyscff6zMnDlTURRFWbJkiTJ+/HhFURQlJydHWbx4sc45iqIoWVlZiru7u7ZCfWBgoOLs7Kyte9izZ0/l008/VRRFUfbs2aON6cyZM0qzZs201/vqq68e+nURoqRIC0+IB1y7dg0XFxfMzc0JCAigXbt2Dz123759Os+3unfvrm3VPA2VSlXkdltbW5o0aQJAw4YNtbF5eHhw8+ZNAE6cOEFmZiazZ89m6tSpbNu2DTMzM5QCVQR79uwJQJMmTbTn9ejRg23btuHl5cWePXv48MMPC90/KCiIGzdu0LZtWwCaNWtGeno6Fy5ceOS1PTw8MDExoU+fPnz//fdMmjTpyb84QjwheYYnxH3R0dEMGjSI5ORk0tPTad26NVevXuXq1as0adKELVu2FDpHeaAU7YOvDXX69GmqV6/+0CLlBYvkqlQq7WuVSqVdFVpRFKysrFi+fLn22NTUVJ0kmneeqamp9rz27dsTHh7Orl27WLJkCf/9738LJe+i3t+D24q6tpWVFRcvXuTw4cNs2LCBefPmceHCBWrXrv34L4oQxURaeELc5+zszLlz5+jduzf/7//9P37++WeeffZZLl68WGSyA80zsWPHjmlf+/n5adfrMlRsbCwzZszgyy+/pGrVqk90DYAuXbqQnJzMtWvXAIiLi2PkyJGPPW/t2rWEh4fz6quvsmvXLvz8/Aod07RpU+rWrat9bnf16lWqVq1Kq1atHnntM2fO4OvrS+/evVm/fj22trZERUU9wbsT4slJC0+IBxw9epQVK1awfv16+vbt+8hj3377ba5du8a7776LqakpTk5OfPDBB0RFReHj40NISAgTJ05k+fLl2uVOQDMtwdfXl6ioKCZOnEhycjJ3795lzpw5DB8+HIA1a9YQEhKCj48Pbm5ufP755yQlJeHj40OjRo3w9/cnJiaGrl278uWXX5KUlMSSJUv48MMP2bp1K1OnTqVRo0YkJyfz7bffAjBz5kwAPv/8c7y8vPD19eX69evs3r2bevXqMWPGDJo2bUpsbCwrVqwA0HZtzpgxg6+//prt27fz5Zdf4uLiQlRUFNu3b6dq1aqsW7dOG2+rVq208S5btozBgwezadMmAgICuHfvHn369HlskhSiuMnyQEIIISoF6dIUQghRKUjCE0IIUSlIwhNCCFEpSMITQghRKUjCE0IIUSlIwhNCCFEpSMITQghRKUjCE0IIUSlIwhNCCFEpSMITQghRKUjCE0IIUSn8f+ilt7PxorEdAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 472.441x236.22 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_size=12\n",
    "y_size=6\n",
    "fontsize = 8\n",
    "fig, ax = plt.subplots(figsize=(x_size/2.54,y_size/2.54))\n",
    "ax.plot(dims, like_evals, '-x', label='This work')\n",
    "#ax.plot(dims[:5], like_evals_polychord[:5], '-o', label='PolyChord')\n",
    "ax.plot(dims_dynesty, like_evals_hslice, '-*', label='DyNesty hslice')\n",
    "ax.plot(dims_dynesty, like_evals_dynesty, '->', label='DyNesty default')\n",
    "#plt.plot(dims, like_evals_slicednest, '.', label='SlicedNest')\n",
    "#plt.plot(dims, like_evals_reflectnest, 'x', label='ReflectNest')\n",
    "ax.set_yscale('log')\n",
    "ax.set_xscale('log')\n",
    "ax.set_xlabel(\"# of Dimensions\", fontsize=fontsize)\n",
    "ax.set_ylabel(r\"# of Likelihood Evaluations\", fontsize=fontsize)\n",
    "ax.set_xticks([4, 8, 16, 32, 64, 128])\n",
    "ax.set_xticklabels(['4', '8', '16', '32', '64', '128'], fontsize=fontsize)\n",
    "ax.set_yticks([1e4, 1e5, 1e6, 1e7, 1e8])\n",
    "ax.set_yticklabels(['$10^4$', '$10^5$', '$10^6$', '$10^7$', '$10^8$'], fontsize=fontsize)\n",
    "plt.legend(fontsize=fontsize)\n",
    "#plt.savefig(\"/Users/pablo/Desktop/ns_comparison\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b7f9adc2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:gns]",
   "language": "python",
   "name": "conda-env-gns-py"
  },
  "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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
