{
 "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=200, #25 * ndims,\n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            sigma_vel=sigma,\n",
    "            min_reflections=1, \n",
    "            max_reflections=3,\n",
    "            tol=1e-2,\n",
    "            clustering=False,\n",
    "            verbose=False)\n",
    "        \n",
    "    ns.run()\n",
    "    an_samples = ns.convert_to_anesthetic()\n",
    "    lZ = an_samples.logZ(nsamples=100)\n",
    "    return ns.get_mean_logZ(), ns.get_var_logZ()**0.5, ns.get_like_evals(), lZ.mean(), lZ.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f6722a2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "D = 4, logZ = -9.2103\n",
      "logZ = -9.1760 +/- 0.1571, like_evals = 202171, time = 33.8963\n",
      "D = 8, logZ = -18.4207\n",
      "logZ = -18.4015 +/- 0.1555, like_evals = 289095, time = 48.0378\n",
      "D = 16, logZ = -36.8414\n",
      "logZ = -36.7981 +/- 0.5417, like_evals = 612454, time = 70.3070\n",
      "D = 32, logZ = -73.6827\n",
      "logZ = -73.3318 +/- 1.4779, like_evals = 1295278, time = 116.0784\n",
      "D = 64, logZ = -147.3654\n",
      "logZ = -148.1386 +/- 0.9837, like_evals = 2782618, time = 236.8287\n",
      "D = 128, logZ = -294.7309\n",
      "logZ = -295.5833 +/- 3.0672, like_evals = 5830562, time = 713.3329\n"
     ]
    }
   ],
   "source": [
    "dims = [4, 8, 16, 32, 64, 128]\n",
    "logZ_true = np.zeros_like(dims, dtype=np.float32)\n",
    "\n",
    "logZ = np.zeros_like(dims, dtype=np.float32)\n",
    "logZ_anesthetic = np.zeros_like(dims, dtype=np.float32)\n",
    "err_logZ = np.zeros_like(dims, dtype=np.float32)\n",
    "err_logZ_anesthetic = 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",
    "    logZ_anesthetic_local = np.zeros(num_repeats, dtype=np.float32)\n",
    "    err_logZ_local = np.zeros(num_repeats, dtype=np.float32)\n",
    "    err_logZ_anesthetic_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], logZ_anesthetic_local[j], err_logZ_anesthetic_local[j] = sample_gaussian(ndims = d, sampler = 'hamiltonian', sigma=0.05)\n",
    "        times_local[j] = time.time() - start_time\n",
    "        \n",
    "    logZ[i] = np.mean(logZ_local)\n",
    "    err_propagated = np.sqrt(np.sum(err_logZ_local**2))/len(err_logZ_local)\n",
    "    err_logZ[i] = np.sqrt(err_propagated**2 + np.std(logZ_local)**2)\n",
    "    logZ_anesthetic[i] = np.mean(logZ_anesthetic_local)\n",
    "    err_logZ_anesthetic[i] = np.sqrt(np.sum(err_logZ_anesthetic_local**2))/len(err_logZ_anesthetic_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}\")\n",
    "    #print(f\"logZ_an = {logZ_anesthetic[i]:.4f} +/- {err_logZ_anesthetic[i]:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cd5ce9e0",
   "metadata": {},
   "outputs": [
    {
     "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_t001\")"
   ]
  },
  {
   "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 0x2acb39ba0>"
      ]
     },
     "execution_count": 6,
     "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.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": 7,
   "id": "b7f9adc2",
   "metadata": {},
   "outputs": [],
   "source": [
    "lz = np.stack([dims, logZ, err_logZ, like_evals, times], axis=1)\n",
    "np.save('./data/hamiltonian_logZ_v3', lz)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2fcc9297",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/Users/pablo/Code/GradNS/nb\r\n"
     ]
    }
   ],
   "source": [
    "!pwd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c476fb3",
   "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
}
