{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "695715d0",
   "metadata": {},
   "source": [
    "# Test of the algorithm on different dimensions"
   ]
  },
  {
   "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.05):\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, \n",
    "            loglike=mvn.log_prob,\n",
    "            params=params,\n",
    "            tol=1e-2,\n",
    "            min_reflections=3, \n",
    "            max_reflections=5,\n",
    "            sigma_vel=sigma,\n",
    "            #dt_ini=0.05,\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()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f6722a2a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "D = 4, logZ = -9.2103\n",
      "logZ = -9.1852 +/- 0.1540, like_evals = 50254, time = 3.5951\n",
      "D = 8, logZ = -18.4207\n",
      "logZ = -18.5326 +/- 0.2369, like_evals = 68175, time = 4.8137\n",
      "D = 16, logZ = -36.8414\n",
      "logZ = -37.4207 +/- 0.6445, like_evals = 99767, time = 7.5970\n",
      "D = 32, logZ = -73.6827\n",
      "logZ = -75.2602 +/- 0.8754, like_evals = 145964, time = 13.1720\n",
      "D = 64, logZ = -147.3654\n",
      "logZ = -150.7174 +/- 1.4082, like_evals = 240022, time = 28.4449\n",
      "D = 128, logZ = -294.7309\n",
      "logZ = -307.4919 +/- 3.0639, like_evals = 433233, time = 63.1858\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",
    "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')\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",
    "    like_evals[i] = np.mean(like_evals_local)\n",
    "    times[i] = np.mean(times_local)\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 0x29d426d10>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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qx4//fQTXFxccPfuXa22fH19dbYvk8k0pq1YsQIdO3bEnDlzEBAQgIiICMyfP1+jyOqj731STVPFlJej6gdI6Rw7dOiA+fPn48aNG+jWrRvq16+PmJgYHDp0CEKICuVI1oGFlei/Fi5cqN7QN2rUCEIIrFu3Tj3QQlJSEjIzM9UxAwYMqFC71W2j+euvvwJ4em2uIZeclBVr6GUrFy5cQGZmpsYjNzcX+fn5+PzzzyvdfpMmTXD69GmcPXsWM2bMQE5ODmbMmIGmTZti9+7d5S5flfepojlOnz4dd+/eRXx8PCIiIpCQkIBevXqhR48eNf764dqEhZXov6ZNm6be0EdHR8PFxQVZWVnIzMzE8uXLoVQqsXPnTnXM9u3bK9Tu888/DwBahy6Bpxvzv/76CzY2NmjWrJlRn48uqp6zADBx4kSTr6+05557DgDw559/6swrKSmpSqM+KRQKAEDbtm3x5Zdf4tq1a9i5cydKSkoq9Fz1vU+qaarnUBlCCCiVSri5uSEmJgY7duxARkYG+vTpgyNHjmDTpk2VbpuqFxZWIh1+/fVXhIeHw97eHsDT61ltbW0RERFhcFvdu3eHVCrF0aNH8eDBA415hw4dQn5+Pl577TV4eHgYI/UyCSEwffp0/P777xgxYoTOc52m9M477wB4eknTs/bu3YtevXqpi2NlBAcH4/Tp0xrTXn/9dbRs2RK5ubnlLj9s2DAAwLZt27TmqaapnkNlrFu3Tj2aloq3tzfGjBkDABXKkawDCyvRM9LT05GRkaEexhB4WljDwsLg6upqcHt16tRBfHw8lEol3nvvPfUG9OrVq5gyZQoaNmyo3os0hSdPnuDw4cPo0aMHFi9ejClTpuD777832frKEhsbix49euDbb79FQkICFAoFhBA4duwYxowZg7i4OPj7+1dpHTNnzsStW7cAPP0hsWvXLly6dAkxMTHlLtumTRvExcXh9OnTmDdvnvr86IEDB7By5Ur06NED48ePr1J+R44cwYYNG9Q/ILKzs7F69Wq4urpW+NQCWQGL9UcmqqbWr18vAKivh8zOzhYAxIcfflildn///XcxYMAAIZVKha+vrwgMDBSxsbEiKytLHVNQUCCkUqlwc3MTAISbm5uQSqXi/fff19t2YmKikEqlwsXFRWM5Hx8f4e3tLdq3by+mTZsmUlNTtZZ99OiRznU+efJEDBs2THh7e6svq5FKpSItLU188cUXQiqVCgDC3t5eSKVScfToUbFu3TohlUqFjY2NsLGxEVKpVHz77bfqdclkMrFgwQLRunVr4enpKQICAkRERITYuHGjRk661nv79m2xefNmrfZXr14thHh6venQoUNFs2bNRP369YWfn59o166d+Pbbb4VcLhdCPL28SSqVCicnJ/UlRNHR0Rrr3rp1q+jcubPw9vYWPj4+olWrVmL+/PlCJpOpYy5cuKDVzsSJE4UQTy8dKv1ahoSECCGEuHv3rpg7d64IDw8XAQEBws/PTwQGBorhw4eLy5cvl/v5IeshEaKa9awgIiKyYjwUTEREZEQsrEREREbEwkpERGRELKxERERGxMJKRERkRCysRERERsTCSkREZEQsrEREREbEwkpERGRELKxERERGxMJKRERkRCysRERERsTCSkREZET/HzhXDJOQPTYTAAAAAElFTkSuQmCC\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 = 14\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='GGNS')\n",
    "ax.axhline(0, ls='--', color='k')\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",
    "plt.legend(fontsize=fontsize)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "0b2e0772",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x29d4340d0>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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1K1b1+zzAgICij02THC69zhwZ+JRTk5OsWOG96F79+7GcVfDz6effgovLy+kpKSUaCswMNBk+1qtttix1atXo3379liwYAFCQkLQqVMnvPXWW8WSZlnK+pwMxwx1yovR8AfF3TG2a9cOb731Fv7880/07NkTwcHBGDNmDL788ssSHQqquhQlSsPM1rsZ7vUiciRLly41fnE3aNAAIoKNGzcab9yPjY1Famqqsc7gwYPNatfRvgS/+eYbAHfuDVWrzf9nXVrdirQB3JnUlJqaWuwnMzMT2dnZeP311xW336hRI5w8eRKnTp3CrFmzkJGRgVmzZqFx48bYt29fuedX5nMyN8ZXXnkFKSkp2LBhAzp16oStW7eib9++6N27d7W/f7WmsNg2WzNmzLBUU0QWM3PmTOMX96OPPgovLy9cu3YNqampWLVqFfR6Pfbs2WOss2vXLrPabdasGQCUuFQI3PlyTk5OhlqtRkREhEVfjymGmaEAMGXKFKs/392aNm0KALhy5YrJuGJjYyu1KpBOpwMAtGnTBosXL0ZCQgL27NmDwsJCs15rWZ+T4ZjhNSghItDr9fD29saYMWOwe/duJCUloX///jhy5Ag+++wzxW2T4+B+lFRjfPPNN+jYsaPxfrtjx47ByckJnTp1qnBbvXr1gkajQVxcHG7cuFGs7Msvv0R2djYee+wx+Pj4WCL0UokIXnnlFfz0008YO3asybFCaxo9ejSAO7fg3OvAgQPo27evMdkpER4ejpMnTxY79vjjj6N58+bIzMws93zDENDOnTtLlBmOGV6DEhs3bjSutmTg7++P5557DgDMipEcHxMl1QgXL15EUlKScdk64E6ibN26NWrVqlXh9jw8PLBhwwbo9Xo8++yzxi/Ec+fOYfr06bjvvvuMvTxryM/Px+HDh9G7d28sX74c06dPx/r16632fKWZNGkSevfujffeew9bt26FTqeDiODo0aN47rnnMG/ePNSrV69SzzFnzhxcunQJwJ0/DPbu3Yvff/8dY8aMKffcBx98EPPmzcPJkyexZMkS4/hidHQ01qxZg969e+Oll16qVHxHjhzB5s2bjX8QpKWlYd26dahVq5bZl/LJwdlpti2RTW3atEkAGO/HS0tLEwAybdq0SrX7008/yeDBg0Wj0UhgYKCEhobKpEmT5Nq1a8Y6OTk5otFoxNvbWwCIt7e3aDQaef7558tsOyYmRjQajXh5eRU7LyAgQPz9/aVt27Yyc+ZMiY+PL3HurVu3TD5nfn6+jBw5Uvz9/Y23gWg0GklMTJSFCxeKRqMRAOLi4iIajUbi4uJk48aNotFojPdLazQaee+994zPpdVq5e2335b7779ffH19JSQkRDp16iRbtmwpFpOp5718+bJ8/vnnJdpft26diNy53/Hpp5+WiIgICQ4OlqCgIHnooYfkvffeMy5XFx0dLRqNRtzd3Y23vDz66KPFnnvHjh3SpUsX8ff3l4CAAGnRooW89dZbotVqjXV+/vnnEu1MmTJFRO7c6nL3exkZGSkiIikpKbJo0SLp2LGjhISESFBQkISGhsqoUaPkjz/+KPf3h6oGs7bZIiIiqql46ZWIiKgMTJRERERlYKIkIiIqAxMlERFRGZgoiYiIysBESUREVAYmSiIiojIwURIREZWBiZKIiKgMTJRERERlYKIkIiIqAxMlERFRGf4PBKR7ynSAHwkAAAAASUVORK5CYII=\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 = 14\n",
    "fig, ax = plt.subplots(figsize=(x_size/2.54,y_size/2.54))\n",
    "ax.errorbar(dims, like_evals, fmt='x', label='GGNS')\n",
    "ax.axhline(0, ls='--', color='k')\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "ax.set_xlabel(\"# of Dimensions\", fontsize=fontsize)\n",
    "ax.set_ylabel(r\"# of Likelihood Evaluations\", fontsize=fontsize)\n",
    "ax.set_xticks(dims)\n",
    "ax.set_xticklabels(np.array(dims, dtype='str'), fontsize=fontsize)\n",
    "plt.legend(fontsize=fontsize)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b7f9adc2",
   "metadata": {},
   "outputs": [],
   "source": [
    "lz = np.stack([dims, logZ, err_logZ, like_evals, times], axis=1)\n",
    "np.save('/Users/pablo/Code/GradNS_dev/nb/data/hamiltonian_logZ_nsteps20_v2', lz)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b33b82d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = np.load('/Users/pablo/Code/GradNS_dev/nb/data/hamiltonian_logZ_v4.npy')\n",
    "dims2, logZ2, err_logZ2, like_evals2, times2 = data[:,0], data[:,1], data[:,2], data[:,3], data[:,4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "aa877bd1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x2c19c13c0>"
      ]
     },
     "execution_count": 8,
     "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 = 14\n",
    "fig, ax = plt.subplots(figsize=(x_size/2.54,y_size/2.54))\n",
    "ax.errorbar(dims, like_evals, fmt='x', label='New')\n",
    "ax.errorbar(dims2, like_evals2, fmt='x', label='Old')\n",
    "ax.axhline(0, ls='--', color='k')\n",
    "ax.set_xscale('log')\n",
    "ax.set_yscale('log')\n",
    "ax.set_ylim([1e5, 1e7])\n",
    "ax.set_xlabel(\"# of Dimensions\", fontsize=fontsize)\n",
    "ax.set_ylabel(r\"# of Likelihood Evaluations\", fontsize=fontsize)\n",
    "ax.set_xticks(dims)\n",
    "ax.set_xticklabels(np.array(dims, dtype='str'), fontsize=fontsize)\n",
    "plt.legend(fontsize=fontsize)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1a5eea3b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 50254,  68175,  99767, 145964, 240022, 433233], dtype=int32)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "like_evals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "24947ca1",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "operands could not be broadcast together with shapes (5,) (6,) ",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Input \u001b[0;32mIn [10]\u001b[0m, in \u001b[0;36m<cell line: 6>\u001b[0;34m()\u001b[0m\n\u001b[1;32m      4\u001b[0m fig, ax \u001b[38;5;241m=\u001b[39m plt\u001b[38;5;241m.\u001b[39msubplots(figsize\u001b[38;5;241m=\u001b[39m(x_size\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2.54\u001b[39m,y_size\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2.54\u001b[39m))\n\u001b[1;32m      5\u001b[0m ax\u001b[38;5;241m.\u001b[39merrorbar(dims, logZ \u001b[38;5;241m-\u001b[39m logZ_true, yerr\u001b[38;5;241m=\u001b[39merr_logZ, fmt\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mx\u001b[39m\u001b[38;5;124m'\u001b[39m, label\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mNew\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[0;32m----> 6\u001b[0m ax\u001b[38;5;241m.\u001b[39merrorbar(dims2[:\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m1.1\u001b[39m, \u001b[43mlogZ2\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mlogZ_true\u001b[49m, yerr\u001b[38;5;241m=\u001b[39merr_logZ2[:\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m], fmt\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mx\u001b[39m\u001b[38;5;124m'\u001b[39m, label\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mOld\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m      7\u001b[0m ax\u001b[38;5;241m.\u001b[39maxhline(\u001b[38;5;241m0\u001b[39m, ls\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m--\u001b[39m\u001b[38;5;124m'\u001b[39m, color\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mk\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m      8\u001b[0m ax\u001b[38;5;241m.\u001b[39mset_xscale(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mlog\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "\u001b[0;31mValueError\u001b[0m: operands could not be broadcast together with shapes (5,) (6,) "
     ]
    },
    {
     "data": {
      "image/png": "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h4fr66+/Vnl5uT/K9guHw6Ht27fr4YcfdvufQMna28XV2vv919XV6bPPPmt2HSv+vtTV1ek///mPwsPDddttt7n119TU6LHHHlNycrLCw8MVGxuradOmac+ePV6tg4CT9M0330iSevXq5bG/Z8+eki7fodbqzpw5oz179mjkyJFuu2sl6b333tPWrVtVXl6uw4cP66677tKSJUs0c+ZM1dXVBaBi7/nb3/6m5cuX6/jx4/r666/1k5/8RJs2bdJtt93WsI1IrW8vrokqVtpeduzYoYsXL7rtYnOx8nZxtfZ+/xUVFaqtrZXNZvM4icmKvy+5ubk6c+aMHnroIfXu3dut/9SpU3I6ncrNzVVVVZXy8/NljFFaWpqee+457xXilyN9ndwDDzxgJJlf//rXHvvT09ONJPP888/7uTL/e/DBB0337t3NwYMH3fr27t1rLly44Nb+ve99z0gyGzZs8EeJPvHJJ5+Yr776yq19/fr1RlKTiRWuSTgFBQUen6t///5Gkvnoo498Vq+/jRgxwtx///0e+6y2XbQ2saK93/8XX3xhJBm73e5x+ZKSEiPJREVFeaV+b2rts/DkwoULZtiwYWbIkCGmurrard/pdJr8/HyP7fHx8cZms5l//etf11D1FYzgdHlatKRmz3dzTZWNjIz0W02BsGPHDmVlZem1117TiBEj3PonTpwou93u1v7QQw9JkrZv3+7zGn3lpptu8jg9edGiRbLZbHrrrbdUWVkpqettL3//+9/173//W0uWLPHYb+XtwpP2fv9dbXv50Y9+pFOnTuntt99WVFSUW39ERITHiUwRERFKT0+XMUY7duzwSi0EnC7vN5fkdqzFxfXDFhcX56+S/C4nJ0eLFi3S73//e82ZM6dd67rOZzl8+LAvSguoqKgoxcXFqb6+XsXFxZJa317Onj0ryTrby4svvqjvfOc7Ho+ltMSq20V7v/9evXrJbrfLGNPQ15iVfl+eeOIJvf7668rJyenQhDxvbzMEnC5Pi5Uun2HviavdtZzV7NmzR7Nnz9bmzZs7dBUBY/HZlle/v5a2l2+++Ubnz59XQkKCx2MPwaasrExvvPFGs6O3llh1u2jv9x8aGqphw4Y1u45Vfl9Wr16tF154QXl5ebr11ls79Bze3mYIOF3exdK9e3d9+OGHbh/wmTNnVFxcrKSkJMucItBYXl6eZs2apY0bN2rRokUN7Z9++mmTyw6tXbvW4/kuklRSUiJJGjp0qG+L9ZGCggINGTLEY191dbVOnTqlkJCQhqt3TJs2TZI8nt/janMtE+xeeuklRUdH67777vPYb+Xtojkd+f6tvs0888wzWr9+vfLy8pqM9HNyclRQUNBk2dmzZyszM9Pj83h9m/HKkTwLWLJkiZFk3nnnnSbt69atM5LM5s2bA1SZ77z77rsmMjLSbN261a3v6itaPPnkkyYuLs5UVVW5LTt9+nQjyfz2t7/1Zbk+s3//fiPJfPjhh259zz//vJFkvvvd7za01dXVmeHDh5vo6Gjz3//+t8ny9957rwkJCfE4SSfYXLp0yfTv3988+uijzS5jxe2iLVcyae/3/8UXX5jw8HBz5513Nml3OBwmISHB9OvXz9TU1Hj1fXhDWyaZrFmzxvTs2dPjpKqMjAzz5JNPNmlLTU0106ZNc1vW4XCYvn37GknmwIED11q6McYYAu5/KisrzbBhw0y/fv3MP/7xD1NTU2P++te/mujoaDNlyhRz8eLFQJfoVfv27TMREREmPj7ezJ071+1x++23Nwm4X/3qV0aSmTRpkvnoo4+M0+k0J0+eNCtXrjSSTFpamqmtrQ3cG7oG+fn5RpIZPHiwefvtt01lZaWprKw027ZtMxEREWbAgAHmxIkTTdb55z//aaKjo83EiRNNSUmJqaqqMk8//bSRZFavXh2gd+Jdb7zxhrHZbKa4uLjZZay4XbTlR70j3//WrVuNJPPII4+YM2fOmJMnT5rZs2ebsLAw8+677/ro3Vyb1j6LZ5991kgyI0aM8Pg7kpiY6BZw48ePN5LM0qVLzdGjR82FCxdMYWGhmTJlipFknnrqKa/VT8A1UllZaZYvX2769etn7Ha7SU5ONqtXr/Y4BTrYuTbclh6NA87pdJo//vGPZtasWWbIkCEmPDzcxMTEmDvvvNO88MIL5tKlS4F7M9eovr7e7N+/3yxatMgMHz7c/N///Z8JDw83N9xwg/nZz35mysvLPa73+eefmzlz5phvfetbJiIiwtx2223mD3/4g5+r9527777bpKWltbiMVbaLY8eONfvfQXPXTezI9797924zduxYExUVZXr06GGmTp3a6U4nac9nMXDgwFZ/R64OuLKyMrNx40YzYcIE079/fxMWFmZiY2PN1KlTze7du736XmzGWPRIMACgS2OSCQDAkgg4AIAlEXAAAEsi4AAAlkTAAQAsiYADAFgSAQcAsCQCDgBgSQQcAMCSCDgAgCURcAAASyLgAACW9P/szO/+iv3+WgAAAABJRU5ErkJggg==\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 = 14\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='New')\n",
    "ax.errorbar(dims2[:-1]*1.1, logZ2[:-1] - logZ_true, yerr=err_logZ2[:-1], fmt='x', label='Old')\n",
    "ax.axhline(0, ls='--', color='k')\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",
    "plt.legend(fontsize=fontsize)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "daa68a15",
   "metadata": {},
   "outputs": [],
   "source": [
    "!ls /Users/pablo/Code/GradNS_dev/nb/data/hamiltonian_logZ_*"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2eb9e4d2",
   "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
}
