{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21432722",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import sys, os\n",
    "sys.path.append('../')\n",
    "result_dir = os.path.join(os.path.dirname(os.getcwd()), 'result', 'gnk')\n",
    "figure_dir = os.path.join(os.path.dirname(os.getcwd()), 'figure')\n",
    "\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import matplotlib\n",
    "\n",
    "plt.rcParams['text.latex.preamble'] = r'\\usepackage{times}'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "f21b22af",
   "metadata": {},
   "outputs": [],
   "source": [
    "# def plot_loss(loss_array, start:int = 0, end: int = None):\n",
    "#     \"\"\"\n",
    "#     Input:\n",
    "#         loss_array: (epoch, 11) array. loss, ell_0, ell_1, ell_2, norm0, norm1, norm2, cos01, cos02, cos12\n",
    "#     \"\"\"\n",
    "\n",
    "#     title_list = ['Loss', r'$\\ell_0$', r'$\\ell_1$', r\"$\\ell_2$\",\n",
    "#                    r'$||\\nabla_0||$', r'$||\\nabla_1||$', r'$||\\nabla_2||$', \n",
    "#                      r'$\\cos(\\nabla_0, \\nabla_1)$', r'$\\cos(\\nabla_0, \\nabla_2)$', r'$\\cos(\\nabla_1, \\nabla_2)$', r'$Var(h_0) - Var(h_1)$',\n",
    "#                      r'$\\cos(\\nabla_0, \\nabla_1 + \\nabla_2$']\n",
    "\n",
    "#     if end is None:\n",
    "#         x_axis = range(start, loss_array.shape[0])\n",
    "#     else:\n",
    "#         x_axis = range(start, end)\n",
    "\n",
    "#     fig, axes = plt.subplots(3, 4, figsize=(20, 10))\n",
    "#     axes = axes.flatten()\n",
    "\n",
    "#     for i in range(len(title_list)):\n",
    "#        axes[i].plot(x_axis, loss_array[start:end, i], label=title_list[i])\n",
    "#        axes[i].set_title(title_list[i])\n",
    "\n",
    "#        if i == 10:\n",
    "#           axes[i].set_xlabel('Epoch')\n",
    "#     # fig.legend()\n",
    "#     fig.tight_layout()\n",
    "\n",
    "#     return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "183edc7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_loss(loss_array, start:int = 0, end: int = None):\n",
    "    \"\"\"\n",
    "    Input:\n",
    "        loss_array: (epoch, 11) array. loss, ell_0, ell_1, ell_2, norm0, norm1, norm2, cos01, cos02, cos12\n",
    "    \"\"\"\n",
    "\n",
    "    title_list = [r'$\\ell_{\\text{M}}$', r'$h_0$', r'$\\bar{f}^{1, +}$', r'$\\bar{f}^{1, -}$']\n",
    "\n",
    "    if end is None:\n",
    "        x_axis = range(start, loss_array.shape[0])\n",
    "    else:\n",
    "        x_axis = range(start, end)\n",
    "\n",
    "    fig, axes = plt.subplots(1, 4, figsize=(13, 2.5))\n",
    "    axes = axes.flatten()\n",
    "\n",
    "    for i in range(len(title_list)):\n",
    "       axes[i].plot(x_axis, loss_array[start:end, i], label=title_list[i])\n",
    "       axes[i].set_title(title_list[i], fontsize = 20)\n",
    "       axes[i].spines['top'].set_visible(False)\n",
    "       axes[i].spines['right'].set_visible(False)\n",
    "       axes[i].spines['top'].set_visible(False)\n",
    "       axes[i].spines['right'].set_visible(False)\n",
    "       axes[i].set_xlabel('Epoch')\n",
    "       if i == 3:\n",
    "          axes[i].set_ylim(-2.5, 0)\n",
    "\n",
    "       elif i ==0:\n",
    "          axes[i].set_ylim(-1, 1.8)\n",
    "\n",
    "       elif i == 1:\n",
    "          axes[i].set_ylim(0, 1.5)\n",
    "\n",
    "       else:\n",
    "           axes[i].set_ylim(-1, 1.5)\n",
    "\n",
    "    #    if i == 10:\n",
    "    #       axes[i].set_xlabel('Epoch')\n",
    "    # fig.legend()\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "e61460e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "loss = np.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_1000_100_gradient_inspect_loss.npy'))\n",
    "# f = plot_loss(loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "871d4668",
   "metadata": {},
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpifcyo6r_ fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpifcyo6r_/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[12], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m loss_to_plot_old \u001b[38;5;241m=\u001b[39m loss[:, \u001b[38;5;241m0\u001b[39m:\u001b[38;5;241m4\u001b[39m]\n\u001b[0;32m----> 2\u001b[0m f \u001b[38;5;241m=\u001b[39m \u001b[43mplot_loss\u001b[49m\u001b[43m(\u001b[49m\u001b[43mloss_to_plot_old\u001b[49m\u001b[43m)\u001b[49m\n",
      "Cell \u001b[0;32mIn[11], line 40\u001b[0m, in \u001b[0;36mplot_loss\u001b[0;34m(loss_array, start, end)\u001b[0m\n\u001b[1;32m     35\u001b[0m        axes[i]\u001b[38;5;241m.\u001b[39mset_ylim(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m1.5\u001b[39m)\n\u001b[1;32m     37\u001b[0m \u001b[38;5;66;03m#    if i == 10:\u001b[39;00m\n\u001b[1;32m     38\u001b[0m \u001b[38;5;66;03m#       axes[i].set_xlabel('Epoch')\u001b[39;00m\n\u001b[1;32m     39\u001b[0m \u001b[38;5;66;03m# fig.legend()\u001b[39;00m\n\u001b[0;32m---> 40\u001b[0m \u001b[43mfig\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtight_layout\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     42\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m fig\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/figure.py:3509\u001b[0m, in \u001b[0;36mFigure.tight_layout\u001b[0;34m(self, pad, h_pad, w_pad, rect)\u001b[0m\n\u001b[1;32m   3507\u001b[0m previous_engine \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_layout_engine()\n\u001b[1;32m   3508\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mset_layout_engine(engine)\n\u001b[0;32m-> 3509\u001b[0m \u001b[43mengine\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mexecute\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3510\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(previous_engine, TightLayoutEngine) \\\n\u001b[1;32m   3511\u001b[0m         \u001b[38;5;129;01mand\u001b[39;00m previous_engine \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   3512\u001b[0m     _api\u001b[38;5;241m.\u001b[39mwarn_external(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mThe figure layout has changed to tight\u001b[39m\u001b[38;5;124m'\u001b[39m)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/layout_engine.py:178\u001b[0m, in \u001b[0;36mTightLayoutEngine.execute\u001b[0;34m(self, fig)\u001b[0m\n\u001b[1;32m    176\u001b[0m renderer \u001b[38;5;241m=\u001b[39m fig\u001b[38;5;241m.\u001b[39m_get_renderer()\n\u001b[1;32m    177\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28mgetattr\u001b[39m(renderer, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m_draw_disabled\u001b[39m\u001b[38;5;124m\"\u001b[39m, nullcontext)():\n\u001b[0;32m--> 178\u001b[0m     kwargs \u001b[38;5;241m=\u001b[39m \u001b[43mget_tight_layout_figure\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    179\u001b[0m \u001b[43m        \u001b[49m\u001b[43mfig\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfig\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43maxes\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mget_subplotspec_list\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfig\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43maxes\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    180\u001b[0m \u001b[43m        \u001b[49m\u001b[43mpad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minfo\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mpad\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mh_pad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minfo\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mh_pad\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mw_pad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minfo\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mw_pad\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    181\u001b[0m \u001b[43m        \u001b[49m\u001b[43mrect\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43minfo\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mrect\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    182\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m kwargs:\n\u001b[1;32m    183\u001b[0m     fig\u001b[38;5;241m.\u001b[39msubplots_adjust(\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/_tight_layout.py:266\u001b[0m, in \u001b[0;36mget_tight_layout_figure\u001b[0;34m(fig, axes_list, subplotspec_list, renderer, pad, h_pad, w_pad, rect)\u001b[0m\n\u001b[1;32m    261\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m {}\n\u001b[1;32m    262\u001b[0m     span_pairs\u001b[38;5;241m.\u001b[39mappend((\n\u001b[1;32m    263\u001b[0m         \u001b[38;5;28mslice\u001b[39m(ss\u001b[38;5;241m.\u001b[39mrowspan\u001b[38;5;241m.\u001b[39mstart \u001b[38;5;241m*\u001b[39m div_row, ss\u001b[38;5;241m.\u001b[39mrowspan\u001b[38;5;241m.\u001b[39mstop \u001b[38;5;241m*\u001b[39m div_row),\n\u001b[1;32m    264\u001b[0m         \u001b[38;5;28mslice\u001b[39m(ss\u001b[38;5;241m.\u001b[39mcolspan\u001b[38;5;241m.\u001b[39mstart \u001b[38;5;241m*\u001b[39m div_col, ss\u001b[38;5;241m.\u001b[39mcolspan\u001b[38;5;241m.\u001b[39mstop \u001b[38;5;241m*\u001b[39m div_col)))\n\u001b[0;32m--> 266\u001b[0m kwargs \u001b[38;5;241m=\u001b[39m \u001b[43m_auto_adjust_subplotpars\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfig\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    267\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43mshape\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mmax_nrows\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmax_ncols\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    268\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43mspan_pairs\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mspan_pairs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    269\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43msubplot_list\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43msubplot_list\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    270\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43max_bbox_list\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43max_bbox_list\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    271\u001b[0m \u001b[43m                                  \u001b[49m\u001b[43mpad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mpad\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mh_pad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mh_pad\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mw_pad\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mw_pad\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    273\u001b[0m \u001b[38;5;66;03m# kwargs can be none if tight_layout fails...\u001b[39;00m\n\u001b[1;32m    274\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m rect \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m kwargs \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    275\u001b[0m     \u001b[38;5;66;03m# if rect is given, the whole subplots area (including\u001b[39;00m\n\u001b[1;32m    276\u001b[0m     \u001b[38;5;66;03m# labels) will fit into the rect instead of the\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    280\u001b[0m     \u001b[38;5;66;03m# auto_adjust_subplotpars twice, where the second run\u001b[39;00m\n\u001b[1;32m    281\u001b[0m     \u001b[38;5;66;03m# with adjusted rect parameters.\u001b[39;00m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/_tight_layout.py:82\u001b[0m, in \u001b[0;36m_auto_adjust_subplotpars\u001b[0;34m(fig, renderer, shape, span_pairs, subplot_list, ax_bbox_list, pad, h_pad, w_pad, rect)\u001b[0m\n\u001b[1;32m     80\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m ax \u001b[38;5;129;01min\u001b[39;00m subplots:\n\u001b[1;32m     81\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m ax\u001b[38;5;241m.\u001b[39mget_visible():\n\u001b[0;32m---> 82\u001b[0m         bb \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m [\u001b[43mmartist\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_tightbbox_for_layout_only\u001b[49m\u001b[43m(\u001b[49m\u001b[43max\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m]\n\u001b[1;32m     84\u001b[0m tight_bbox_raw \u001b[38;5;241m=\u001b[39m Bbox\u001b[38;5;241m.\u001b[39munion(bb)\n\u001b[1;32m     85\u001b[0m tight_bbox \u001b[38;5;241m=\u001b[39m fig\u001b[38;5;241m.\u001b[39mtransFigure\u001b[38;5;241m.\u001b[39minverted()\u001b[38;5;241m.\u001b[39mtransform_bbox(tight_bbox_raw)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:1415\u001b[0m, in \u001b[0;36m_get_tightbbox_for_layout_only\u001b[0;34m(obj, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1409\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   1410\u001b[0m \u001b[38;5;124;03mMatplotlib's `.Axes.get_tightbbox` and `.Axis.get_tightbbox` support a\u001b[39;00m\n\u001b[1;32m   1411\u001b[0m \u001b[38;5;124;03m*for_layout_only* kwarg; this helper tries to use the kwarg but skips it\u001b[39;00m\n\u001b[1;32m   1412\u001b[0m \u001b[38;5;124;03mwhen encountering third-party subclasses that do not support it.\u001b[39;00m\n\u001b[1;32m   1413\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m   1414\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m-> 1415\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mobj\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_tightbbox\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43m{\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mfor_layout_only\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m:\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m}\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1416\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[1;32m   1417\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m obj\u001b[38;5;241m.\u001b[39mget_tightbbox(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:4388\u001b[0m, in \u001b[0;36m_AxesBase.get_tightbbox\u001b[0;34m(self, renderer, call_axes_locator, bbox_extra_artists, for_layout_only)\u001b[0m\n\u001b[1;32m   4386\u001b[0m         \u001b[38;5;28;01mif\u001b[39;00m ba:\n\u001b[1;32m   4387\u001b[0m             bb\u001b[38;5;241m.\u001b[39mappend(ba)\n\u001b[0;32m-> 4388\u001b[0m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_update_title_position\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   4389\u001b[0m axbbox \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_window_extent(renderer)\n\u001b[1;32m   4390\u001b[0m bb\u001b[38;5;241m.\u001b[39mappend(axbbox)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:2982\u001b[0m, in \u001b[0;36m_AxesBase._update_title_position\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   2980\u001b[0m     _log\u001b[38;5;241m.\u001b[39mdebug(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtop of Axes not in the figure, so title not moved\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m   2981\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m\n\u001b[0;32m-> 2982\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[43mtitle\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_window_extent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mymin \u001b[38;5;241m<\u001b[39m top:\n\u001b[1;32m   2983\u001b[0m     _, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtransAxes\u001b[38;5;241m.\u001b[39minverted()\u001b[38;5;241m.\u001b[39mtransform((\u001b[38;5;241m0\u001b[39m, top))\n\u001b[1;32m   2984\u001b[0m     title\u001b[38;5;241m.\u001b[39mset_position((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:959\u001b[0m, in \u001b[0;36mText.get_window_extent\u001b[0;34m(self, renderer, dpi)\u001b[0m\n\u001b[1;32m    954\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    955\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCannot get window extent of text w/o renderer. You likely \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    956\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mwant to call \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfigure.draw_without_rendering()\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m first.\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m    958\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m cbook\u001b[38;5;241m.\u001b[39m_setattr_cm(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfigure, dpi\u001b[38;5;241m=\u001b[39mdpi):\n\u001b[0;32m--> 959\u001b[0m     bbox, info, descent \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_layout\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_renderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    960\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_unitless_position()\n\u001b[1;32m    961\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_transform()\u001b[38;5;241m.\u001b[39mtransform((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:386\u001b[0m, in \u001b[0;36mText._get_layout\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m    384\u001b[0m clean_line, ismath \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_preprocess_math(line)\n\u001b[1;32m    385\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m clean_line:\n\u001b[0;32m--> 386\u001b[0m     w, h, d \u001b[38;5;241m=\u001b[39m \u001b[43m_get_text_metrics_with_cache\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    387\u001b[0m \u001b[43m        \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mclean_line\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_fontproperties\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    388\u001b[0m \u001b[43m        \u001b[49m\u001b[43mismath\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfigure\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    389\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    390\u001b[0m     w \u001b[38;5;241m=\u001b[39m h \u001b[38;5;241m=\u001b[39m d \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:97\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache\u001b[0;34m(renderer, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m     94\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Call ``renderer.get_text_width_height_descent``, caching the results.\"\"\"\u001b[39;00m\n\u001b[1;32m     95\u001b[0m \u001b[38;5;66;03m# Cached based on a copy of fontprop so that later in-place mutations of\u001b[39;00m\n\u001b[1;32m     96\u001b[0m \u001b[38;5;66;03m# the passed-in argument do not mess up the cache.\u001b[39;00m\n\u001b[0;32m---> 97\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_get_text_metrics_with_cache_impl\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m     98\u001b[0m \u001b[43m    \u001b[49m\u001b[43mweakref\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mref\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:105\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache_impl\u001b[0;34m(renderer_ref, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m    101\u001b[0m \u001b[38;5;129m@functools\u001b[39m\u001b[38;5;241m.\u001b[39mlru_cache(\u001b[38;5;241m4096\u001b[39m)\n\u001b[1;32m    102\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21m_get_text_metrics_with_cache_impl\u001b[39m(\n\u001b[1;32m    103\u001b[0m         renderer_ref, text, fontprop, ismath, dpi):\n\u001b[1;32m    104\u001b[0m     \u001b[38;5;66;03m# dpi is unused, but participates in cache invalidation (via the renderer).\u001b[39;00m\n\u001b[0;32m--> 105\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mrenderer_ref\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backends/backend_agg.py:226\u001b[0m, in \u001b[0;36mRendererAgg.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    224\u001b[0m _api\u001b[38;5;241m.\u001b[39mcheck_in_list([\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;28;01mTrue\u001b[39;00m, \u001b[38;5;28;01mFalse\u001b[39;00m], ismath\u001b[38;5;241m=\u001b[39mismath)\n\u001b[1;32m    225\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[0;32m--> 226\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43msuper\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    228\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n\u001b[1;32m    229\u001b[0m     ox, oy, width, height, descent, font_image \u001b[38;5;241m=\u001b[39m \\\n\u001b[1;32m    230\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmathtext_parser\u001b[38;5;241m.\u001b[39mparse(s, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdpi, prop)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backend_bases.py:645\u001b[0m, in \u001b[0;36mRendererBase.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    641\u001b[0m fontsize \u001b[38;5;241m=\u001b[39m prop\u001b[38;5;241m.\u001b[39mget_size_in_points()\n\u001b[1;32m    643\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    644\u001b[0m     \u001b[38;5;66;03m# todo: handle properties\u001b[39;00m\n\u001b[0;32m--> 645\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_texmanager\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    646\u001b[0m \u001b[43m        \u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    648\u001b[0m dpi \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m72\u001b[39m)\n\u001b[1;32m    649\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:368\u001b[0m, in \u001b[0;36mTexManager.get_text_width_height_descent\u001b[0;34m(cls, tex, fontsize, renderer)\u001b[0m\n\u001b[1;32m    366\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m tex\u001b[38;5;241m.\u001b[39mstrip() \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    367\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m\n\u001b[0;32m--> 368\u001b[0m dvifile \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmake_dvi\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    369\u001b[0m dpi_fraction \u001b[38;5;241m=\u001b[39m renderer\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m1.\u001b[39m) \u001b[38;5;28;01mif\u001b[39;00m renderer \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    370\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m dviread\u001b[38;5;241m.\u001b[39mDvi(dvifile, \u001b[38;5;241m72\u001b[39m \u001b[38;5;241m*\u001b[39m dpi_fraction) \u001b[38;5;28;01mas\u001b[39;00m dvi:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:300\u001b[0m, in \u001b[0;36mTexManager.make_dvi\u001b[0;34m(cls, tex, fontsize)\u001b[0m\n\u001b[1;32m    298\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m TemporaryDirectory(\u001b[38;5;28mdir\u001b[39m\u001b[38;5;241m=\u001b[39mcwd) \u001b[38;5;28;01mas\u001b[39;00m tmpdir:\n\u001b[1;32m    299\u001b[0m         tmppath \u001b[38;5;241m=\u001b[39m Path(tmpdir)\n\u001b[0;32m--> 300\u001b[0m         \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_run_checked_subprocess\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    301\u001b[0m \u001b[43m            \u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mlatex\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m-interaction=nonstopmode\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--halt-on-error\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    302\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--output-directory=\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtmppath\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    303\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtexfile\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcwd\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcwd\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    304\u001b[0m         (tmppath \u001b[38;5;241m/\u001b[39m Path(dvifile)\u001b[38;5;241m.\u001b[39mname)\u001b[38;5;241m.\u001b[39mreplace(dvifile)\n\u001b[1;32m    305\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m dvifile\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:263\u001b[0m, in \u001b[0;36mTexManager._run_checked_subprocess\u001b[0;34m(cls, command, tex, cwd)\u001b[0m\n\u001b[1;32m    259\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    260\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mFailed to process string with tex because \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m could not be \u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    261\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfound\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(command[\u001b[38;5;241m0\u001b[39m])) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mexc\u001b[39;00m\n\u001b[1;32m    262\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m subprocess\u001b[38;5;241m.\u001b[39mCalledProcessError \u001b[38;5;28;01mas\u001b[39;00m exc:\n\u001b[0;32m--> 263\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    264\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{prog}\u001b[39;00m\u001b[38;5;124m was not able to process the following string:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    265\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{tex!r}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    266\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHere is the full command invocation and its output:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    267\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{format_command}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    268\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{exc}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(\n\u001b[1;32m    269\u001b[0m             prog\u001b[38;5;241m=\u001b[39mcommand[\u001b[38;5;241m0\u001b[39m],\n\u001b[1;32m    270\u001b[0m             format_command\u001b[38;5;241m=\u001b[39mcbook\u001b[38;5;241m.\u001b[39m_pformat_subprocess(command),\n\u001b[1;32m    271\u001b[0m             tex\u001b[38;5;241m=\u001b[39mtex\u001b[38;5;241m.\u001b[39mencode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124municode_escape\u001b[39m\u001b[38;5;124m'\u001b[39m),\n\u001b[1;32m    272\u001b[0m             exc\u001b[38;5;241m=\u001b[39mexc\u001b[38;5;241m.\u001b[39moutput\u001b[38;5;241m.\u001b[39mdecode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mbackslashreplace\u001b[39m\u001b[38;5;124m'\u001b[39m))\n\u001b[1;32m    273\u001b[0m         ) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[1;32m    274\u001b[0m _log\u001b[38;5;241m.\u001b[39mdebug(report)\n\u001b[1;32m    275\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m report\n",
      "\u001b[0;31mRuntimeError\u001b[0m: latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpifcyo6r_ fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpifcyo6r_/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error in callback <function _draw_all_if_interactive at 0x11cb8d700> (for post_execute), with arguments args (),kwargs {}:\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpl0l4un8j fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpl0l4un8j/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/pyplot.py:120\u001b[0m, in \u001b[0;36m_draw_all_if_interactive\u001b[0;34m()\u001b[0m\n\u001b[1;32m    118\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21m_draw_all_if_interactive\u001b[39m():\n\u001b[1;32m    119\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m matplotlib\u001b[38;5;241m.\u001b[39mis_interactive():\n\u001b[0;32m--> 120\u001b[0m         \u001b[43mdraw_all\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/_pylab_helpers.py:132\u001b[0m, in \u001b[0;36mGcf.draw_all\u001b[0;34m(cls, force)\u001b[0m\n\u001b[1;32m    130\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m manager \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mcls\u001b[39m\u001b[38;5;241m.\u001b[39mget_all_fig_managers():\n\u001b[1;32m    131\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m force \u001b[38;5;129;01mor\u001b[39;00m manager\u001b[38;5;241m.\u001b[39mcanvas\u001b[38;5;241m.\u001b[39mfigure\u001b[38;5;241m.\u001b[39mstale:\n\u001b[0;32m--> 132\u001b[0m         \u001b[43mmanager\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcanvas\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw_idle\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backend_bases.py:2082\u001b[0m, in \u001b[0;36mFigureCanvasBase.draw_idle\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   2080\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_is_idle_drawing:\n\u001b[1;32m   2081\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_idle_draw_cntx():\n\u001b[0;32m-> 2082\u001b[0m         \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backends/backend_agg.py:400\u001b[0m, in \u001b[0;36mFigureCanvasAgg.draw\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    396\u001b[0m \u001b[38;5;66;03m# Acquire a lock on the shared font cache.\u001b[39;00m\n\u001b[1;32m    397\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m RendererAgg\u001b[38;5;241m.\u001b[39mlock, \\\n\u001b[1;32m    398\u001b[0m      (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtoolbar\u001b[38;5;241m.\u001b[39m_wait_cursor_for_draw_cm() \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtoolbar\n\u001b[1;32m    399\u001b[0m       \u001b[38;5;28;01melse\u001b[39;00m nullcontext()):\n\u001b[0;32m--> 400\u001b[0m     \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfigure\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    401\u001b[0m     \u001b[38;5;66;03m# A GUI class may be need to update a window using this draw, so\u001b[39;00m\n\u001b[1;32m    402\u001b[0m     \u001b[38;5;66;03m# don't forget to call the superclass.\u001b[39;00m\n\u001b[1;32m    403\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39mdraw()\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:95\u001b[0m, in \u001b[0;36m_finalize_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer, *args, **kwargs)\u001b[0m\n\u001b[1;32m     93\u001b[0m \u001b[38;5;129m@wraps\u001b[39m(draw)\n\u001b[1;32m     94\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21mdraw_wrapper\u001b[39m(artist, renderer, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[0;32m---> 95\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     96\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m renderer\u001b[38;5;241m.\u001b[39m_rasterizing:\n\u001b[1;32m     97\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstop_rasterizing()\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:72\u001b[0m, in \u001b[0;36mallow_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer)\u001b[0m\n\u001b[1;32m     69\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     70\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstart_filter()\n\u001b[0;32m---> 72\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     73\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m     74\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/figure.py:3140\u001b[0m, in \u001b[0;36mFigure.draw\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   3137\u001b[0m         \u001b[38;5;66;03m# ValueError can occur when resizing a window.\u001b[39;00m\n\u001b[1;32m   3139\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mpatch\u001b[38;5;241m.\u001b[39mdraw(renderer)\n\u001b[0;32m-> 3140\u001b[0m \u001b[43mmimage\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_draw_list_compositing_images\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m   3141\u001b[0m \u001b[43m    \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43martists\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msuppressComposite\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3143\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m sfig \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39msubfigs:\n\u001b[1;32m   3144\u001b[0m     sfig\u001b[38;5;241m.\u001b[39mdraw(renderer)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/image.py:131\u001b[0m, in \u001b[0;36m_draw_list_compositing_images\u001b[0;34m(renderer, parent, artists, suppress_composite)\u001b[0m\n\u001b[1;32m    129\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m not_composite \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m has_images:\n\u001b[1;32m    130\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m a \u001b[38;5;129;01min\u001b[39;00m artists:\n\u001b[0;32m--> 131\u001b[0m         \u001b[43ma\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    132\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    133\u001b[0m     \u001b[38;5;66;03m# Composite any adjacent images together\u001b[39;00m\n\u001b[1;32m    134\u001b[0m     image_group \u001b[38;5;241m=\u001b[39m []\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:72\u001b[0m, in \u001b[0;36mallow_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer)\u001b[0m\n\u001b[1;32m     69\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     70\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstart_filter()\n\u001b[0;32m---> 72\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     73\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m     74\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:3028\u001b[0m, in \u001b[0;36m_AxesBase.draw\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   3025\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m spine \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mspines\u001b[38;5;241m.\u001b[39mvalues():\n\u001b[1;32m   3026\u001b[0m         artists\u001b[38;5;241m.\u001b[39mremove(spine)\n\u001b[0;32m-> 3028\u001b[0m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_update_title_position\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3030\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39maxison:\n\u001b[1;32m   3031\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m _axis \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_axis_map\u001b[38;5;241m.\u001b[39mvalues():\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:2982\u001b[0m, in \u001b[0;36m_AxesBase._update_title_position\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   2980\u001b[0m     _log\u001b[38;5;241m.\u001b[39mdebug(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtop of Axes not in the figure, so title not moved\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m   2981\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m\n\u001b[0;32m-> 2982\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[43mtitle\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_window_extent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mymin \u001b[38;5;241m<\u001b[39m top:\n\u001b[1;32m   2983\u001b[0m     _, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtransAxes\u001b[38;5;241m.\u001b[39minverted()\u001b[38;5;241m.\u001b[39mtransform((\u001b[38;5;241m0\u001b[39m, top))\n\u001b[1;32m   2984\u001b[0m     title\u001b[38;5;241m.\u001b[39mset_position((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:959\u001b[0m, in \u001b[0;36mText.get_window_extent\u001b[0;34m(self, renderer, dpi)\u001b[0m\n\u001b[1;32m    954\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    955\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCannot get window extent of text w/o renderer. You likely \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    956\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mwant to call \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfigure.draw_without_rendering()\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m first.\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m    958\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m cbook\u001b[38;5;241m.\u001b[39m_setattr_cm(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfigure, dpi\u001b[38;5;241m=\u001b[39mdpi):\n\u001b[0;32m--> 959\u001b[0m     bbox, info, descent \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_layout\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_renderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    960\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_unitless_position()\n\u001b[1;32m    961\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_transform()\u001b[38;5;241m.\u001b[39mtransform((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:386\u001b[0m, in \u001b[0;36mText._get_layout\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m    384\u001b[0m clean_line, ismath \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_preprocess_math(line)\n\u001b[1;32m    385\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m clean_line:\n\u001b[0;32m--> 386\u001b[0m     w, h, d \u001b[38;5;241m=\u001b[39m \u001b[43m_get_text_metrics_with_cache\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    387\u001b[0m \u001b[43m        \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mclean_line\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_fontproperties\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    388\u001b[0m \u001b[43m        \u001b[49m\u001b[43mismath\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfigure\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    389\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    390\u001b[0m     w \u001b[38;5;241m=\u001b[39m h \u001b[38;5;241m=\u001b[39m d \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:97\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache\u001b[0;34m(renderer, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m     94\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Call ``renderer.get_text_width_height_descent``, caching the results.\"\"\"\u001b[39;00m\n\u001b[1;32m     95\u001b[0m \u001b[38;5;66;03m# Cached based on a copy of fontprop so that later in-place mutations of\u001b[39;00m\n\u001b[1;32m     96\u001b[0m \u001b[38;5;66;03m# the passed-in argument do not mess up the cache.\u001b[39;00m\n\u001b[0;32m---> 97\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_get_text_metrics_with_cache_impl\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m     98\u001b[0m \u001b[43m    \u001b[49m\u001b[43mweakref\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mref\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:105\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache_impl\u001b[0;34m(renderer_ref, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m    101\u001b[0m \u001b[38;5;129m@functools\u001b[39m\u001b[38;5;241m.\u001b[39mlru_cache(\u001b[38;5;241m4096\u001b[39m)\n\u001b[1;32m    102\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21m_get_text_metrics_with_cache_impl\u001b[39m(\n\u001b[1;32m    103\u001b[0m         renderer_ref, text, fontprop, ismath, dpi):\n\u001b[1;32m    104\u001b[0m     \u001b[38;5;66;03m# dpi is unused, but participates in cache invalidation (via the renderer).\u001b[39;00m\n\u001b[0;32m--> 105\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mrenderer_ref\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backends/backend_agg.py:226\u001b[0m, in \u001b[0;36mRendererAgg.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    224\u001b[0m _api\u001b[38;5;241m.\u001b[39mcheck_in_list([\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;28;01mTrue\u001b[39;00m, \u001b[38;5;28;01mFalse\u001b[39;00m], ismath\u001b[38;5;241m=\u001b[39mismath)\n\u001b[1;32m    225\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[0;32m--> 226\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43msuper\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    228\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n\u001b[1;32m    229\u001b[0m     ox, oy, width, height, descent, font_image \u001b[38;5;241m=\u001b[39m \\\n\u001b[1;32m    230\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmathtext_parser\u001b[38;5;241m.\u001b[39mparse(s, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdpi, prop)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backend_bases.py:645\u001b[0m, in \u001b[0;36mRendererBase.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    641\u001b[0m fontsize \u001b[38;5;241m=\u001b[39m prop\u001b[38;5;241m.\u001b[39mget_size_in_points()\n\u001b[1;32m    643\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    644\u001b[0m     \u001b[38;5;66;03m# todo: handle properties\u001b[39;00m\n\u001b[0;32m--> 645\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_texmanager\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    646\u001b[0m \u001b[43m        \u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    648\u001b[0m dpi \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m72\u001b[39m)\n\u001b[1;32m    649\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:368\u001b[0m, in \u001b[0;36mTexManager.get_text_width_height_descent\u001b[0;34m(cls, tex, fontsize, renderer)\u001b[0m\n\u001b[1;32m    366\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m tex\u001b[38;5;241m.\u001b[39mstrip() \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    367\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m\n\u001b[0;32m--> 368\u001b[0m dvifile \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmake_dvi\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    369\u001b[0m dpi_fraction \u001b[38;5;241m=\u001b[39m renderer\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m1.\u001b[39m) \u001b[38;5;28;01mif\u001b[39;00m renderer \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    370\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m dviread\u001b[38;5;241m.\u001b[39mDvi(dvifile, \u001b[38;5;241m72\u001b[39m \u001b[38;5;241m*\u001b[39m dpi_fraction) \u001b[38;5;28;01mas\u001b[39;00m dvi:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:300\u001b[0m, in \u001b[0;36mTexManager.make_dvi\u001b[0;34m(cls, tex, fontsize)\u001b[0m\n\u001b[1;32m    298\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m TemporaryDirectory(\u001b[38;5;28mdir\u001b[39m\u001b[38;5;241m=\u001b[39mcwd) \u001b[38;5;28;01mas\u001b[39;00m tmpdir:\n\u001b[1;32m    299\u001b[0m         tmppath \u001b[38;5;241m=\u001b[39m Path(tmpdir)\n\u001b[0;32m--> 300\u001b[0m         \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_run_checked_subprocess\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    301\u001b[0m \u001b[43m            \u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mlatex\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m-interaction=nonstopmode\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--halt-on-error\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    302\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--output-directory=\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtmppath\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    303\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtexfile\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcwd\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcwd\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    304\u001b[0m         (tmppath \u001b[38;5;241m/\u001b[39m Path(dvifile)\u001b[38;5;241m.\u001b[39mname)\u001b[38;5;241m.\u001b[39mreplace(dvifile)\n\u001b[1;32m    305\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m dvifile\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:263\u001b[0m, in \u001b[0;36mTexManager._run_checked_subprocess\u001b[0;34m(cls, command, tex, cwd)\u001b[0m\n\u001b[1;32m    259\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    260\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mFailed to process string with tex because \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m could not be \u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    261\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfound\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(command[\u001b[38;5;241m0\u001b[39m])) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mexc\u001b[39;00m\n\u001b[1;32m    262\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m subprocess\u001b[38;5;241m.\u001b[39mCalledProcessError \u001b[38;5;28;01mas\u001b[39;00m exc:\n\u001b[0;32m--> 263\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    264\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{prog}\u001b[39;00m\u001b[38;5;124m was not able to process the following string:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    265\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{tex!r}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    266\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHere is the full command invocation and its output:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    267\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{format_command}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    268\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{exc}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(\n\u001b[1;32m    269\u001b[0m             prog\u001b[38;5;241m=\u001b[39mcommand[\u001b[38;5;241m0\u001b[39m],\n\u001b[1;32m    270\u001b[0m             format_command\u001b[38;5;241m=\u001b[39mcbook\u001b[38;5;241m.\u001b[39m_pformat_subprocess(command),\n\u001b[1;32m    271\u001b[0m             tex\u001b[38;5;241m=\u001b[39mtex\u001b[38;5;241m.\u001b[39mencode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124municode_escape\u001b[39m\u001b[38;5;124m'\u001b[39m),\n\u001b[1;32m    272\u001b[0m             exc\u001b[38;5;241m=\u001b[39mexc\u001b[38;5;241m.\u001b[39moutput\u001b[38;5;241m.\u001b[39mdecode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mbackslashreplace\u001b[39m\u001b[38;5;124m'\u001b[39m))\n\u001b[1;32m    273\u001b[0m         ) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[1;32m    274\u001b[0m _log\u001b[38;5;241m.\u001b[39mdebug(report)\n\u001b[1;32m    275\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m report\n",
      "\u001b[0;31mRuntimeError\u001b[0m: latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpl0l4un8j fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpl0l4un8j/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpw70nh7w1 fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpw70nh7w1/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/IPython/core/formatters.py:340\u001b[0m, in \u001b[0;36mBaseFormatter.__call__\u001b[0;34m(self, obj)\u001b[0m\n\u001b[1;32m    338\u001b[0m     \u001b[38;5;28;01mpass\u001b[39;00m\n\u001b[1;32m    339\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m--> 340\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mprinter\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    341\u001b[0m \u001b[38;5;66;03m# Finally look for special method names\u001b[39;00m\n\u001b[1;32m    342\u001b[0m method \u001b[38;5;241m=\u001b[39m get_real_method(obj, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mprint_method)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/IPython/core/pylabtools.py:152\u001b[0m, in \u001b[0;36mprint_figure\u001b[0;34m(fig, fmt, bbox_inches, base64, **kwargs)\u001b[0m\n\u001b[1;32m    149\u001b[0m     \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mmatplotlib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mbackend_bases\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mimport\u001b[39;00m FigureCanvasBase\n\u001b[1;32m    150\u001b[0m     FigureCanvasBase(fig)\n\u001b[0;32m--> 152\u001b[0m \u001b[43mfig\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcanvas\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mprint_figure\u001b[49m\u001b[43m(\u001b[49m\u001b[43mbytes_io\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkw\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    153\u001b[0m data \u001b[38;5;241m=\u001b[39m bytes_io\u001b[38;5;241m.\u001b[39mgetvalue()\n\u001b[1;32m    154\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m fmt \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124msvg\u001b[39m\u001b[38;5;124m'\u001b[39m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backend_bases.py:2342\u001b[0m, in \u001b[0;36mFigureCanvasBase.print_figure\u001b[0;34m(self, filename, dpi, facecolor, edgecolor, orientation, format, bbox_inches, pad_inches, bbox_extra_artists, backend, **kwargs)\u001b[0m\n\u001b[1;32m   2336\u001b[0m     renderer \u001b[38;5;241m=\u001b[39m _get_renderer(\n\u001b[1;32m   2337\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfigure,\n\u001b[1;32m   2338\u001b[0m         functools\u001b[38;5;241m.\u001b[39mpartial(\n\u001b[1;32m   2339\u001b[0m             print_method, orientation\u001b[38;5;241m=\u001b[39morientation)\n\u001b[1;32m   2340\u001b[0m     )\n\u001b[1;32m   2341\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m \u001b[38;5;28mgetattr\u001b[39m(renderer, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m_draw_disabled\u001b[39m\u001b[38;5;124m\"\u001b[39m, nullcontext)():\n\u001b[0;32m-> 2342\u001b[0m         \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfigure\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   2344\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m bbox_inches:\n\u001b[1;32m   2345\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m bbox_inches \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtight\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:95\u001b[0m, in \u001b[0;36m_finalize_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer, *args, **kwargs)\u001b[0m\n\u001b[1;32m     93\u001b[0m \u001b[38;5;129m@wraps\u001b[39m(draw)\n\u001b[1;32m     94\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21mdraw_wrapper\u001b[39m(artist, renderer, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[0;32m---> 95\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     96\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m renderer\u001b[38;5;241m.\u001b[39m_rasterizing:\n\u001b[1;32m     97\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstop_rasterizing()\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:72\u001b[0m, in \u001b[0;36mallow_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer)\u001b[0m\n\u001b[1;32m     69\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     70\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstart_filter()\n\u001b[0;32m---> 72\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     73\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m     74\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/figure.py:3140\u001b[0m, in \u001b[0;36mFigure.draw\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   3137\u001b[0m         \u001b[38;5;66;03m# ValueError can occur when resizing a window.\u001b[39;00m\n\u001b[1;32m   3139\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mpatch\u001b[38;5;241m.\u001b[39mdraw(renderer)\n\u001b[0;32m-> 3140\u001b[0m \u001b[43mmimage\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_draw_list_compositing_images\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m   3141\u001b[0m \u001b[43m    \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43martists\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43msuppressComposite\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3143\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m sfig \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39msubfigs:\n\u001b[1;32m   3144\u001b[0m     sfig\u001b[38;5;241m.\u001b[39mdraw(renderer)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/image.py:131\u001b[0m, in \u001b[0;36m_draw_list_compositing_images\u001b[0;34m(renderer, parent, artists, suppress_composite)\u001b[0m\n\u001b[1;32m    129\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m not_composite \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m has_images:\n\u001b[1;32m    130\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m a \u001b[38;5;129;01min\u001b[39;00m artists:\n\u001b[0;32m--> 131\u001b[0m         \u001b[43ma\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    132\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    133\u001b[0m     \u001b[38;5;66;03m# Composite any adjacent images together\u001b[39;00m\n\u001b[1;32m    134\u001b[0m     image_group \u001b[38;5;241m=\u001b[39m []\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/artist.py:72\u001b[0m, in \u001b[0;36mallow_rasterization.<locals>.draw_wrapper\u001b[0;34m(artist, renderer)\u001b[0m\n\u001b[1;32m     69\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     70\u001b[0m         renderer\u001b[38;5;241m.\u001b[39mstart_filter()\n\u001b[0;32m---> 72\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mdraw\u001b[49m\u001b[43m(\u001b[49m\u001b[43martist\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     73\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m     74\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m artist\u001b[38;5;241m.\u001b[39mget_agg_filter() \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:3028\u001b[0m, in \u001b[0;36m_AxesBase.draw\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   3025\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m spine \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mspines\u001b[38;5;241m.\u001b[39mvalues():\n\u001b[1;32m   3026\u001b[0m         artists\u001b[38;5;241m.\u001b[39mremove(spine)\n\u001b[0;32m-> 3028\u001b[0m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_update_title_position\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   3030\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39maxison:\n\u001b[1;32m   3031\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m _axis \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_axis_map\u001b[38;5;241m.\u001b[39mvalues():\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/axes/_base.py:2982\u001b[0m, in \u001b[0;36m_AxesBase._update_title_position\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m   2980\u001b[0m     _log\u001b[38;5;241m.\u001b[39mdebug(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtop of Axes not in the figure, so title not moved\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m   2981\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m\n\u001b[0;32m-> 2982\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[43mtitle\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_window_extent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mymin \u001b[38;5;241m<\u001b[39m top:\n\u001b[1;32m   2983\u001b[0m     _, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mtransAxes\u001b[38;5;241m.\u001b[39minverted()\u001b[38;5;241m.\u001b[39mtransform((\u001b[38;5;241m0\u001b[39m, top))\n\u001b[1;32m   2984\u001b[0m     title\u001b[38;5;241m.\u001b[39mset_position((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:959\u001b[0m, in \u001b[0;36mText.get_window_extent\u001b[0;34m(self, renderer, dpi)\u001b[0m\n\u001b[1;32m    954\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    955\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCannot get window extent of text w/o renderer. You likely \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    956\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mwant to call \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfigure.draw_without_rendering()\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m first.\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m    958\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m cbook\u001b[38;5;241m.\u001b[39m_setattr_cm(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfigure, dpi\u001b[38;5;241m=\u001b[39mdpi):\n\u001b[0;32m--> 959\u001b[0m     bbox, info, descent \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_get_layout\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_renderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    960\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_unitless_position()\n\u001b[1;32m    961\u001b[0m     x, y \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mget_transform()\u001b[38;5;241m.\u001b[39mtransform((x, y))\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:386\u001b[0m, in \u001b[0;36mText._get_layout\u001b[0;34m(self, renderer)\u001b[0m\n\u001b[1;32m    384\u001b[0m clean_line, ismath \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_preprocess_math(line)\n\u001b[1;32m    385\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m clean_line:\n\u001b[0;32m--> 386\u001b[0m     w, h, d \u001b[38;5;241m=\u001b[39m \u001b[43m_get_text_metrics_with_cache\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    387\u001b[0m \u001b[43m        \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mclean_line\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_fontproperties\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    388\u001b[0m \u001b[43m        \u001b[49m\u001b[43mismath\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfigure\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    389\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m    390\u001b[0m     w \u001b[38;5;241m=\u001b[39m h \u001b[38;5;241m=\u001b[39m d \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:97\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache\u001b[0;34m(renderer, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m     94\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Call ``renderer.get_text_width_height_descent``, caching the results.\"\"\"\u001b[39;00m\n\u001b[1;32m     95\u001b[0m \u001b[38;5;66;03m# Cached based on a copy of fontprop so that later in-place mutations of\u001b[39;00m\n\u001b[1;32m     96\u001b[0m \u001b[38;5;66;03m# the passed-in argument do not mess up the cache.\u001b[39;00m\n\u001b[0;32m---> 97\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_get_text_metrics_with_cache_impl\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m     98\u001b[0m \u001b[43m    \u001b[49m\u001b[43mweakref\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mref\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcopy\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdpi\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/text.py:105\u001b[0m, in \u001b[0;36m_get_text_metrics_with_cache_impl\u001b[0;34m(renderer_ref, text, fontprop, ismath, dpi)\u001b[0m\n\u001b[1;32m    101\u001b[0m \u001b[38;5;129m@functools\u001b[39m\u001b[38;5;241m.\u001b[39mlru_cache(\u001b[38;5;241m4096\u001b[39m)\n\u001b[1;32m    102\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21m_get_text_metrics_with_cache_impl\u001b[39m(\n\u001b[1;32m    103\u001b[0m         renderer_ref, text, fontprop, ismath, dpi):\n\u001b[1;32m    104\u001b[0m     \u001b[38;5;66;03m# dpi is unused, but participates in cache invalidation (via the renderer).\u001b[39;00m\n\u001b[0;32m--> 105\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mrenderer_ref\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backends/backend_agg.py:226\u001b[0m, in \u001b[0;36mRendererAgg.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    224\u001b[0m _api\u001b[38;5;241m.\u001b[39mcheck_in_list([\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m, \u001b[38;5;28;01mTrue\u001b[39;00m, \u001b[38;5;28;01mFalse\u001b[39;00m], ismath\u001b[38;5;241m=\u001b[39mismath)\n\u001b[1;32m    225\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m\"\u001b[39m:\n\u001b[0;32m--> 226\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43msuper\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mprop\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mismath\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    228\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n\u001b[1;32m    229\u001b[0m     ox, oy, width, height, descent, font_image \u001b[38;5;241m=\u001b[39m \\\n\u001b[1;32m    230\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmathtext_parser\u001b[38;5;241m.\u001b[39mparse(s, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdpi, prop)\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/backend_bases.py:645\u001b[0m, in \u001b[0;36mRendererBase.get_text_width_height_descent\u001b[0;34m(self, s, prop, ismath)\u001b[0m\n\u001b[1;32m    641\u001b[0m fontsize \u001b[38;5;241m=\u001b[39m prop\u001b[38;5;241m.\u001b[39mget_size_in_points()\n\u001b[1;32m    643\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mTeX\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    644\u001b[0m     \u001b[38;5;66;03m# todo: handle properties\u001b[39;00m\n\u001b[0;32m--> 645\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_texmanager\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mget_text_width_height_descent\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    646\u001b[0m \u001b[43m        \u001b[49m\u001b[43ms\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    648\u001b[0m dpi \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m72\u001b[39m)\n\u001b[1;32m    649\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m ismath:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:368\u001b[0m, in \u001b[0;36mTexManager.get_text_width_height_descent\u001b[0;34m(cls, tex, fontsize, renderer)\u001b[0m\n\u001b[1;32m    366\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m tex\u001b[38;5;241m.\u001b[39mstrip() \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m'\u001b[39m:\n\u001b[1;32m    367\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m\n\u001b[0;32m--> 368\u001b[0m dvifile \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmake_dvi\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mfontsize\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    369\u001b[0m dpi_fraction \u001b[38;5;241m=\u001b[39m renderer\u001b[38;5;241m.\u001b[39mpoints_to_pixels(\u001b[38;5;241m1.\u001b[39m) \u001b[38;5;28;01mif\u001b[39;00m renderer \u001b[38;5;28;01melse\u001b[39;00m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    370\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m dviread\u001b[38;5;241m.\u001b[39mDvi(dvifile, \u001b[38;5;241m72\u001b[39m \u001b[38;5;241m*\u001b[39m dpi_fraction) \u001b[38;5;28;01mas\u001b[39;00m dvi:\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:300\u001b[0m, in \u001b[0;36mTexManager.make_dvi\u001b[0;34m(cls, tex, fontsize)\u001b[0m\n\u001b[1;32m    298\u001b[0m     \u001b[38;5;28;01mwith\u001b[39;00m TemporaryDirectory(\u001b[38;5;28mdir\u001b[39m\u001b[38;5;241m=\u001b[39mcwd) \u001b[38;5;28;01mas\u001b[39;00m tmpdir:\n\u001b[1;32m    299\u001b[0m         tmppath \u001b[38;5;241m=\u001b[39m Path(tmpdir)\n\u001b[0;32m--> 300\u001b[0m         \u001b[38;5;28;43mcls\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_run_checked_subprocess\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    301\u001b[0m \u001b[43m            \u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mlatex\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m-interaction=nonstopmode\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--halt-on-error\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    302\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43m--output-directory=\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtmppath\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[1;32m    303\u001b[0m \u001b[43m             \u001b[49m\u001b[38;5;124;43mf\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43mtexfile\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mname\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtex\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcwd\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mcwd\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    304\u001b[0m         (tmppath \u001b[38;5;241m/\u001b[39m Path(dvifile)\u001b[38;5;241m.\u001b[39mname)\u001b[38;5;241m.\u001b[39mreplace(dvifile)\n\u001b[1;32m    305\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m dvifile\n",
      "File \u001b[0;32m/opt/homebrew/anaconda3/envs/sbi_env/lib/python3.9/site-packages/matplotlib/texmanager.py:263\u001b[0m, in \u001b[0;36mTexManager._run_checked_subprocess\u001b[0;34m(cls, command, tex, cwd)\u001b[0m\n\u001b[1;32m    259\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    260\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mFailed to process string with tex because \u001b[39m\u001b[38;5;132;01m{}\u001b[39;00m\u001b[38;5;124m could not be \u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    261\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfound\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(command[\u001b[38;5;241m0\u001b[39m])) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mexc\u001b[39;00m\n\u001b[1;32m    262\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m subprocess\u001b[38;5;241m.\u001b[39mCalledProcessError \u001b[38;5;28;01mas\u001b[39;00m exc:\n\u001b[0;32m--> 263\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[1;32m    264\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{prog}\u001b[39;00m\u001b[38;5;124m was not able to process the following string:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    265\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{tex!r}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    266\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mHere is the full command invocation and its output:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    267\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{format_command}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m    268\u001b[0m         \u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{exc}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;241m.\u001b[39mformat(\n\u001b[1;32m    269\u001b[0m             prog\u001b[38;5;241m=\u001b[39mcommand[\u001b[38;5;241m0\u001b[39m],\n\u001b[1;32m    270\u001b[0m             format_command\u001b[38;5;241m=\u001b[39mcbook\u001b[38;5;241m.\u001b[39m_pformat_subprocess(command),\n\u001b[1;32m    271\u001b[0m             tex\u001b[38;5;241m=\u001b[39mtex\u001b[38;5;241m.\u001b[39mencode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124municode_escape\u001b[39m\u001b[38;5;124m'\u001b[39m),\n\u001b[1;32m    272\u001b[0m             exc\u001b[38;5;241m=\u001b[39mexc\u001b[38;5;241m.\u001b[39moutput\u001b[38;5;241m.\u001b[39mdecode(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mutf-8\u001b[39m\u001b[38;5;124m'\u001b[39m, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mbackslashreplace\u001b[39m\u001b[38;5;124m'\u001b[39m))\n\u001b[1;32m    273\u001b[0m         ) \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[1;32m    274\u001b[0m _log\u001b[38;5;241m.\u001b[39mdebug(report)\n\u001b[1;32m    275\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m report\n",
      "\u001b[0;31mRuntimeError\u001b[0m: latex was not able to process the following string:\nb'$\\\\\\\\ell_{\\\\\\\\text{M}}$'\n\nHere is the full command invocation and its output:\n\nlatex -interaction=nonstopmode --halt-on-error --output-directory=tmpw70nh7w1 fcc87265619e0c6d83020830a79fb33f.tex\n\nThis is pdfTeX, Version 3.141592653-2.6-1.40.27 (TeX Live 2025) (preloaded format=latex)\n restricted \\write18 enabled.\nentering extended mode\n(./fcc87265619e0c6d83020830a79fb33f.tex\nLaTeX2e <2024-11-01> patch level 2\nL3 programming layer <2025-01-18>\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/article.cls\nDocument Class: article 2024/06/29 v1.4n Standard LaTeX document class\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/size10.clo))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/type1cm/type1cm.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/cm-super/type1ec.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/t1cmr.fd))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/inputenc.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/geometry/geometry.sty\n(/usr/local/texlive/2025/texmf-dist/tex/latex/graphics/keyval.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/ifvtex.sty\n(/usr/local/texlive/2025/texmf-dist/tex/generic/iftex/iftex.sty)))\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/times.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/underscore/underscore.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/firstaid/underscore-ltx.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/base/textcomp.sty)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/psnfss/ot1ptm.fd)\n(/usr/local/texlive/2025/texmf-dist/tex/latex/l3backend/l3backend-dvips.def)\nNo file fcc87265619e0c6d83020830a79fb33f.aux.\n*geometry* driver: auto-detecting\n*geometry* detected driver: dvips\n! Undefined control sequence.\nl.29 {\\rmfamily $\\ell_{\\text\n                            {M}}$}%\nNo pages of output.\nTranscript written on tmpw70nh7w1/fcc87265619e0c6d83020830a79fb33f.log.\n\n\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1300x250 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loss_to_plot_old = loss[:, 0:4]\n",
    "f = plot_loss(loss_to_plot_old)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "2ec5cbd0",
   "metadata": {},
   "outputs": [],
   "source": [
    "f.savefig(os.path.join(figure_dir, 'loss_old_gnk.pdf'), bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "af7a6335",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1300x250 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loss_new = np.load(os.path.join(result_dir, 'gnk_nle_mlmc_n_1000_100_loss.npy'))\n",
    "loss_to_plot_new = loss_new[:, 0:4]\n",
    "f_new = plot_loss(loss_to_plot_new)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "cc4f187e",
   "metadata": {},
   "outputs": [],
   "source": [
    "f_new.savefig(os.path.join(figure_dir, 'loss_new_gnk.pdf'), bbox_inches = 'tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "2cd9cc96",
   "metadata": {},
   "outputs": [],
   "source": [
    "loss_to_plot_new = loss[:, 0:4]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "61baf171",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sbi_env",
   "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.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
