{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## System Info"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'platform': 'Linux',\n",
       " 'platform-release': '3.10.0-1160.21.1.el7.x86_64',\n",
       " 'platform-version': '#1 SMP Tue Mar 16 18:28:22 UTC 2021',\n",
       " 'architecture': 'x86_64',\n",
       " 'hostname': 'statgpu.snu.ac.kr',\n",
       " 'processor': 'x86_64'}"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import platform, socket, re, uuid, json, logging\n",
    "\n",
    "def getSystemInfo():\n",
    "    try:\n",
    "        info={}\n",
    "        info['platform']=platform.system()\n",
    "        info['platform-release']=platform.release()\n",
    "        info['platform-version']=platform.version()\n",
    "        info['architecture']=platform.machine()\n",
    "        info['hostname']=socket.gethostname()\n",
    "        info['processor']=platform.processor()\n",
    "        return json.dumps(info)\n",
    "    except Exception as e:\n",
    "        logging.exception(e)\n",
    "\n",
    "json.loads(getSystemInfo())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import sys\n",
    "import torch \n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset\n",
    "from torch.utils.data import DataLoader\n",
    "from scipy.stats import norm\n",
    "import pickle\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "\n",
    "sys.path.append(\"src\")\n",
    "\n",
    "from SBNN.model import Model\n",
    "from example import BesovFunction, func_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "seed = 1\n",
    "DTYPE = torch.float64 # to check model structure\n",
    "torch.set_default_dtype(DTYPE)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/lkw1718/documents/APforBNNinBesov/src/example.py:126: RuntimeWarning: divide by zero encountered in log\n",
      "  return np.where(x > 0, 1/np.log(x/2), 0)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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x3jyBBFR56SNOcyYMQNCiKh/RETUOQ4KExFpigFNRKQpBjQRkaYY0EREmmJAExFpSunFkqxqO+KDV7UjIq9oy7N4jmjTOqCbmpoAAPn5+S5XQkTkrKamJmRlZZ13GmVXs7MjHA7j2LFjyMjIsHSR+bar4NXX13v2Gh5eX0Yun/m8vox2l08IgaamJuTl5XV6+QutO+jk5OQOZyFakZmZ6ckV47u8voxcPvN5fRntLF9nnXMb7iQkItIUA5qISFOeDOhAIICKigoEAgG3S5HG68vI5TOf15dRxfJpvZOQiMjPPNlBExF5AQOaiEhTDGgiIk0xoImINMWAJiLSlLEBvWjRIvTv3x/p6ekoKirCBx98cN7pV65cicLCQqSnp2PYsGFYu3atokrts7KMzz33HMaNG4fu3buje/fumDRpUqfvidusfoZtqqurkZSUhBtuuEFugQmyunxff/01SktLkZubi0AggMGDB2u/nlpdxqeffhqXXnopunTpgvz8fNx777349ttvFVVrzebNmzF16lTk5eUhKSkJr732WqfP2bRpEy6//HIEAgEMGjQIVVVViRUhDFRdXS3S0tLEsmXLxEcffSRmzpwpunXrJo4fPx51+q1bt4qUlBTx5JNPir1794o//OEP4oILLhB79uxRXHn8rC7jrbfeKhYtWiR2794t9u3bJ2bMmCGysrLE559/rrjy+FhdvjaHDh0SF198sRg3bpy4/vrr1RRrg9XlC4VCYtSoUeLaa68VW7ZsEYcOHRKbNm0StbW1iiuPn9VlXLFihQgEAmLFihXi0KFDYv369SI3N1fce++9iiuPz9q1a8WcOXPEqlWrBACxevXq805/8OBB0bVrV1FWVib27t0rnnnmGZGSkiLWrVtnuwYjA3r06NGitLQ0cru1tVXk5eWJysrKqNPfdNNN4rrrrmt3X1FRkbjzzjul1pkIq8t4rpaWFpGRkSGWL18uq8SE2Fm+lpYWMWbMGPH888+LkpISrQPa6vItXrxYFBQUiObmZlUlJszqMpaWloqJEye2u6+srExcddVVUut0QjwB/fvf/14MGTKk3X0333yzmDx5su35GjfE0dzcjJqaGkyaNClyX3JyMiZNmoRt27ZFfc62bdvaTQ8AkydPjjm92+ws47nOnDmDs2fPokePHrLKtM3u8v3xj39ETk4Obr/9dhVl2mZn+f7xj3+guLgYpaWl6N27N4YOHYonnngCra2tqsq2xM4yjhkzBjU1NZFhkIMHD2Lt2rW49tprldQsm4yc0fpqdtGcOnUKra2t6N27d7v7e/fujf3790d9TkNDQ9TpGxoapNWZCDvLeK4HH3wQeXl5HVYYHdhZvi1btuCFF15AbW2tggoTY2f5Dh48iLfffhvTpk3D2rVrUVdXh7vvvhtnz55FRUWFirItsbOMt956K06dOoWxY8dCCIGWlhb85je/wUMPPaSiZOli5UwwGMR///tfdOnSxfJrGtdBU+fmz5+P6upqrF69Gunp6W6Xk7CmpiZMnz4dzz33HHr16uV2OVKEw2Hk5OTg2WefxciRI3HzzTdjzpw5WLJkidulOWbTpk144okn8Ne//hW7du3CqlWrsGbNGjz22GNul6Yt4zroXr16ISUlBcePH293//Hjx9GnT5+oz+nTp4+l6d1mZxnbLFy4EPPnz8eGDRswfPhwmWXaZnX5Pv30Uxw+fBhTp06N3BcOhwEAqampOHDgAAYOHCi3aAvsfH65ubm44IILkJKSErnve9/7HhoaGtDc3Iy0tDSpNVtlZxkffvhhTJ8+Hb/+9a8BAMOGDcPp06dxxx13YM6cOZ1evF53sXImMzPTVvcMGNhBp6WlYeTIkdi4cWPkvnA4jI0bN6K4uDjqc4qLi9tNDwBvvfVWzOndZmcZAeDJJ5/EY489hnXr1mHUqFEqSrXF6vIVFhZiz549qK2tjfz97Gc/w9VXX43a2lrtfhLNzud31VVXoa6uLvLFAwAff/wxcnNztQtnwN4ynjlzpkMIt30hCQ9cs01Kztjeveii6upqEQgERFVVldi7d6+44447RLdu3URDQ4MQQojp06eL2bNnR6bfunWrSE1NFQsXLhT79u0TFRUVRhxmZ2UZ58+fL9LS0sSrr74qvvjii8hfU1OTW4twXlaX71y6H8VhdfmOHDkiMjIyxKxZs8SBAwfEm2++KXJycsTjjz/u1iJ0yuoyVlRUiIyMDPG3v/1NHDx4UPzrX/8SAwcOFDfddJNbi3BeTU1NYvfu3WL37t0CgHjqqafE7t27xWeffSaEEGL27Nli+vTpkenbDrN74IEHxL59+8SiRYv8eZidEEI888wzol+/fiItLU2MHj1abN++PfLY+PHjRUlJSbvpX3nlFTF48GCRlpYmhgwZItasWaO4YuusLOMll1wiAHT4q6ioUF94nKx+ht+le0ALYX353nvvPVFUVCQCgYAoKCgQ8+bNEy0tLYqrtsbKMp49e1Y8+uijYuDAgSI9PV3k5+eLu+++W/znP/9RX3gc3nnnnajbVNsylZSUiPHjx3d4zogRI0RaWpooKCgQL774YkI18HrQRESaMm4MmojILxjQRESaYkATEWmKAU1EpCkGNBGRphjQRESaYkATEWmKAU1EpCkGNBGRphjQRESaYkATEWnq/wF8JQb0aIRr2AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x_grid = np.linspace(0, 1, 1000)\n",
    "for func in [\"cantor\", \"sobolev\", \"blocks\", \"heavisine\"]:\n",
    "    besov_ = BesovFunction(func_dict[func][\"func\"])\n",
    "    y_grid = besov_(x_grid)\n",
    "    fig = plt.figure(figsize = (4, 4))\n",
    "    plt.plot(x_grid, y_grid, \"k-\")\n",
    "    plt.savefig(f\"figs/{func}_fn.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Check Model Structure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def format_tex(float_number, sig=4):\n",
    "    exponent = np.floor(np.log10(float_number))\n",
    "    mantissa = float_number/10**exponent\n",
    "    mantissa_format = str(mantissa)[0:(1+sig)]\n",
    "    return \"${0}\\\\times10^{{{1}}}$\"\\\n",
    "           .format(mantissa_format, str(int(exponent)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calc_structure(func, n):\n",
    "    d = 1\n",
    "    s = func_dict[func][\"s\"]\n",
    "    p = func_dict[func][\"p\"]\n",
    "    F = func_dict[func][\"F\"]\n",
    "    sigma = func_dict[func][\"sigma\"]\n",
    "    W = 200\n",
    "    L = 5\n",
    "    info_dict = {}\n",
    "    model = Model(n=n, d=d, s=s, p=p, batch_size=min([100, n]), scale_data=sigma, F=F, verbose=False)\n",
    "    info_dict[\"full\"] = model.info(verbose=False)\n",
    "    model = Model(n=n, d=d, s=s, p=p, batch_size=min([100, n]), scale_data=sigma, W=W, L=L, F=F, verbose=False)\n",
    "    info_dict[\"mini\"] = model.info(verbose=False)\n",
    "\n",
    "    return info_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "hparams1 = {\"full\": {}, \"mini\": {}}\n",
    "hparams2 = {\"full\": {}, \"mini\": {}}\n",
    "for n in [100, 1000, 10000]:\n",
    "    info1 = calc_structure(\"cantor\", n)\n",
    "    info2 = calc_structure(\"sobolev\", n)\n",
    "    for size in [\"full\", \"mini\"]:\n",
    "        hparams1[size][f\"{n:,}\"] = pd.Series({\"$L$\": info1[size][\"L\"], \"$W$\": info1[size][\"W\"],\n",
    "            \"$\\\\sigma_{1n}$\": info1[size][\"scale_param\"][0], \"$\\\\sigma_{2n}$\": info1[size][\"scale_param\"][1],\n",
    "            \"$\\\\pi_{1n}$\": info1[size][\"mixture\"][0], \"$\\\\pi_{2n}$\": info1[size][\"mixture\"][1]})\n",
    "        hparams2[size][f\"{n:,}\"] = pd.Series({\"$L$\": info2[size][\"L\"], \"$W$\": info2[size][\"W\"],\n",
    "            \"$\\\\sigma_{1n}$\": info2[size][\"scale_param\"][0], \"$\\\\sigma_{2n}$\": info2[size][\"scale_param\"][1],\n",
    "            \"$\\\\pi_{1n}$\": info2[size][\"mixture\"][0], \"$\\\\pi_{2n}$\": info2[size][\"mixture\"][1]})\n",
    "        if size == \"mini\":\n",
    "            hparams1[size][f\"{n:,}\"][\"$\\\\sigma_{1n}$\"] = 0.001\n",
    "            hparams2[size][f\"{n:,}\"][\"$\\\\sigma_{1n}$\"] = 0.001"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Full"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table}[ht]\n",
      "\\centering\n",
      "\\caption{Hyperparameters of BNN to estimate $f_1 \\in B_{\\infty, \\infty}^{\\log2 / \\log 3}([0, 1])$.}\n",
      "\\label{table:f1_networks}\n",
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & $L$ & $W$ & $\\sigma_{1n}$ & $\\sigma_{2n}$ & $\\pi_{1n}$ & $\\pi_{2n}$ \\\\\n",
      "\\midrule\n",
      "100 & 39 & 400 & $3.747\\times10^{-179}$ & $8.443\\times10^{-1}$ & $8.719\\times10^{-1}$ & $1.280\\times10^{-1}$ \\\\\n",
      "1,000 & 43 & 1,100 & $1.505\\times10^{-234}$ & $7.597\\times10^{-1}$ & $9.534\\times10^{-1}$ & $4.651\\times10^{-2}$ \\\\\n",
      "10,000 & 45 & 2,950 & $1.508\\times10^{-283}$ & $7.954\\times10^{-1}$ & $9.826\\times10^{-1}$ & $1.733\\times10^{-2}$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\\end{table}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df = pd.DataFrame(hparams1[\"full\"]).T\n",
    "df.iloc[:, 2:] = df.iloc[:, 2:].applymap(lambda x: format_tex(x, sig=4))\n",
    "df.iloc[:, :2] = df.iloc[:, :2].applymap(lambda x: f\"{int(x):,}\")\n",
    "\n",
    "print(\n",
    "    df.style.to_latex(column_format=\"lrrrrrr\", position=\"ht\", position_float=\"centering\", hrules=True, label=\"table:f1_networks\",\n",
    "        caption=\"Hyperparameters of BNN to estimate $f_1 \\in B_{\\infty, \\infty}^{\\log2 / \\log 3}([0, 1])$.\",\n",
    "        multirow_align=\"t\", multicol_align=\"r\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table}[ht]\n",
      "\\centering\n",
      "\\caption{Hyperparameters of BNN to estimate $f_2,~f_3$ and $f_4 \\in B^{1}_{1, 1}([0, 1])$.}\n",
      "\\label{table:f2_networks}\n",
      "\\begin{tabular}{lrrrrrr}\n",
      "\\toprule\n",
      " & $L$ & $W$ & $\\sigma_{1n}$ & $\\sigma_{2n}$ & $\\pi_{1n}$ & $\\pi_{2n}$ \\\\\n",
      "\\midrule\n",
      "100 & 41 & 250 & $8.669\\times10^{-172}$ & $6.779\\times10^{-1}$ & $7.957\\times10^{-1}$ & $2.042\\times10^{-1}$ \\\\\n",
      "1,000 & 43 & 500 & $1.259\\times10^{-205}$ & $5.028\\times10^{-1}$ & $8.977\\times10^{-1}$ & $1.022\\times10^{-1}$ \\\\\n",
      "10,000 & 47 & 1,100 & $1.963\\times10^{-256}$ & $4.894\\times10^{-1}$ & $9.535\\times10^{-1}$ & $4.642\\times10^{-2}$ \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\\end{table}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "df = pd.DataFrame(hparams2[\"full\"]).T\n",
    "df.iloc[:, 2:] = df.iloc[:, 2:].applymap(lambda x: format_tex(x, sig=4))\n",
    "df.iloc[:, :2] = df.iloc[:, :2].applymap(lambda x: f\"{int(x):,}\")\n",
    "\n",
    "print(\n",
    "    df.style.to_latex(column_format=\"lrrrrrr\", position=\"ht\", position_float=\"centering\", hrules=True, label=\"table:f2_networks\",\n",
    "        caption=\"Hyperparameters of BNN to estimate $f_2,~f_3$ and $f_4 \\in B^{1}_{1, 1}([0, 1])$.\",\n",
    "        multirow_align=\"t\", multicol_align=\"r\")\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Error Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# load errors\n",
    "empirical_dict = {}\n",
    "test_dict = {}\n",
    "seed = 1\n",
    "for func in [\"cantor\", \"sobolev\", \"blocks\", \"heavisine\"]:\n",
    "    empirical_dict[func] = {}\n",
    "    test_dict[func] = {}\n",
    "    for n in [100, 1000, 10000]:\n",
    "        empirical_dict[func][f\"{n:,}\"] = {}\n",
    "        test_dict[func][f\"{n:,}\"] = {}\n",
    "        for prior in [\"2GMM\", \"Gaussian\"]:\n",
    "            empirical_dict[func][f\"{n:,}\"][prior] = np.load(f\"results/{func}_{prior}_{n}_err_{seed}.npy\")\n",
    "            test_dict[func][f\"{n:,}\"][prior] = np.load(f\"results/{func}_{prior}_{n}_err_test_{seed}.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "empirical_df = pd.DataFrame.from_dict({(i,j): empirical_dict[i][j]\n",
    "                           for i in empirical_dict.keys() \n",
    "                           for j in empirical_dict[i].keys()},\n",
    "                           orient='index')\n",
    "\n",
    "test_df = pd.DataFrame.from_dict({(i,j): test_dict[i][j]\n",
    "                           for i in test_dict.keys() \n",
    "                           for j in test_dict[i].keys()},\n",
    "                           orient='index')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summarise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_error_df(df, caption, label):\n",
    "    df = df.rename(columns = {\"2GMM\": \"Gaussian mixture BNN\", \"Gaussian\": \"Gaussian BNN\"},\n",
    "            index = {\"cantor\": \"$f_1$\", \"sobolev\": \"$f_2$\", \"blocks\": \"$f_3$\", \"heavisine\": \"$f_4$\"})\n",
    "    mean_df = df.applymap(lambda x: np.nanmean(x))\n",
    "    std_df = df.applymap(lambda x: \" (\" + format_tex(np.nanstd(x), sig=4) + \")\")\n",
    "    styled = mean_df.style.highlight_min(props=\"color:{blue};\", axis=1)\n",
    "    styled.data = mean_df.applymap(lambda x: format_tex(x, sig=4)) + std_df\n",
    "    print(\n",
    "        styled.to_latex(column_format=\"lrrr\", position=\"ht\", position_float=\"centering\",\n",
    "            hrules=True, label=label,\n",
    "            caption=caption,\n",
    "            multirow_align=\"t\", multicol_align=\"r\")\n",
    "    )\n",
    "    return styled"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table}[ht]\n",
      "\\centering\n",
      "\\caption{Summary statistics of the empirical errors between true functions and sampled functions, where the numbers in the parentheses denote the standard deviations.}\n",
      "\\label{table:EE}\n",
      "\\begin{tabular}{lrrr}\n",
      "\\toprule\n",
      " &  & Gaussian mixture BNN & Gaussian BNN \\\\\n",
      "\\midrule\n",
      "\\multirow[t]{3}{*}{$f_1$} & 100 & $1.398\\times10^{-2}$ ($8.896\\times10^{-4}$) & \\color{blue} $1.386\\times10^{-2}$ ($8.774\\times10^{-4}$) \\\\\n",
      " & 1,000 & \\color{blue} $1.451\\times10^{-2}$ ($2.899\\times10^{-4}$) & $1.455\\times10^{-2}$ ($2.840\\times10^{-4}$) \\\\\n",
      " & 10,000 & \\color{blue} $1.455\\times10^{-2}$ ($9.233\\times10^{-5}$) & $1.461\\times10^{-2}$ ($8.763\\times10^{-5}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_2$} & 100 & \\color{blue} $1.336\\times10^{-2}$ ($8.119\\times10^{-4}$) & $1.359\\times10^{-2}$ ($9.023\\times10^{-4}$) \\\\\n",
      " & 1,000 & \\color{blue} $1.424\\times10^{-2}$ ($2.781\\times10^{-4}$) & $1.427\\times10^{-2}$ ($2.741\\times10^{-4}$) \\\\\n",
      " & 10,000 & $1.420\\times10^{-2}$ ($8.728\\times10^{-5}$) & \\color{blue} $1.419\\times10^{-2}$ ($8.651\\times10^{-5}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_3$} & 100 & \\color{blue} $1.428\\times10^{-1}$ ($9.301\\times10^{-3}$) & $1.497\\times10^{-1}$ ($9.356\\times10^{-3}$) \\\\\n",
      " & 1,000 & $2.297\\times10^{-1}$ ($4.256\\times10^{-3}$) & \\color{blue} $2.289\\times10^{-1}$ ($4.632\\times10^{-3}$) \\\\\n",
      " & 10,000 & \\color{blue} $2.200\\times10^{-1}$ ($3.228\\times10^{-3}$) & $2.204\\times10^{-1}$ ($2.668\\times10^{-3}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_4$} & 100 & \\color{blue} $1.389\\times10^{-1}$ ($9.279\\times10^{-3}$) & $1.390\\times10^{-1}$ ($9.085\\times10^{-3}$) \\\\\n",
      " & 1,000 & \\color{blue} $1.430\\times10^{-1}$ ($2.898\\times10^{-3}$) & $1.460\\times10^{-1}$ ($2.921\\times10^{-3}$) \\\\\n",
      " & 10,000 & $1.543\\times10^{-1}$ ($8.986\\times10^{-4}$) & \\color{blue} $1.500\\times10^{-1}$ ($8.825\\times10^{-4}$) \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\\end{table}\n",
      "\n",
      "\\begin{table}[ht]\n",
      "\\centering\n",
      "\\caption{Summary statistics of the test errors between true functions and sampled functions, where the numbers in the parentheses denotes the standard deviations.}\n",
      "\\label{table:L2}\n",
      "\\begin{tabular}{lrrr}\n",
      "\\toprule\n",
      " &  & Gaussian mixture BNN & Gaussian BNN \\\\\n",
      "\\midrule\n",
      "\\multirow[t]{3}{*}{$f_1$} & 100 & \\color{blue} $1.921\\times10^{-2}$ ($1.441\\times10^{-3}$) & $2.359\\times10^{-2}$ ($3.646\\times10^{-3}$) \\\\\n",
      " & 1,000 & \\color{blue} $1.327\\times10^{-2}$ ($3.172\\times10^{-4}$) & $1.335\\times10^{-2}$ ($5.983\\times10^{-4}$) \\\\\n",
      " & 10,000 & $1.212\\times10^{-2}$ ($2.808\\times10^{-4}$) & \\color{blue} $1.201\\times10^{-2}$ ($2.643\\times10^{-4}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_2$} & 100 & \\color{blue} $1.363\\times10^{-2}$ ($6.582\\times10^{-4}$) & $1.652\\times10^{-2}$ ($2.293\\times10^{-3}$) \\\\\n",
      " & 1,000 & \\color{blue} $1.151\\times10^{-2}$ ($3.835\\times10^{-4}$) & $1.164\\times10^{-2}$ ($4.203\\times10^{-4}$) \\\\\n",
      " & 10,000 & $1.177\\times10^{-2}$ ($2.626\\times10^{-4}$) & \\color{blue} $1.155\\times10^{-2}$ ($2.529\\times10^{-4}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_3$} & 100 & $1.120\\times10^{0}$ ($5.175\\times10^{-2}$) & \\color{blue} $1.041\\times10^{0}$ ($6.923\\times10^{-2}$) \\\\\n",
      " & 1,000 & $3.750\\times10^{-1}$ ($5.497\\times10^{-3}$) & \\color{blue} $3.699\\times10^{-1}$ ($6.699\\times10^{-3}$) \\\\\n",
      " & 10,000 & \\color{blue} $2.478\\times10^{-1}$ ($4.589\\times10^{-3}$) & $2.479\\times10^{-1}$ ($4.036\\times10^{-3}$) \\\\\n",
      "\\multirow[t]{3}{*}{$f_4$} & 100 & $4.942\\times10^{-1}$ ($2.930\\times10^{-2}$) & \\color{blue} $4.493\\times10^{-1}$ ($4.450\\times10^{-2}$) \\\\\n",
      " & 1,000 & $1.715\\times10^{-1}$ ($8.959\\times10^{-3}$) & \\color{blue} $1.666\\times10^{-1}$ ($1.029\\times10^{-2}$) \\\\\n",
      " & 10,000 & $1.550\\times10^{-1}$ ($3.242\\times10^{-3}$) & \\color{blue} $1.128\\times10^{-1}$ ($2.454\\times10^{-3}$) \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\\end{table}\n",
      "\n"
     ]
    }
   ],
   "source": [
    "EE_res = print_error_df(empirical_df,\n",
    "    label=\"table:EE\",\n",
    "    caption=\"Summary statistics of the empirical errors between true functions and sampled functions, where the numbers in the parentheses denote the standard deviations.\"\n",
    ")\n",
    "\n",
    "L2_res = print_error_df(test_df,\n",
    "    label=\"table:L2\",\n",
    "    caption=\"Summary statistics of the test errors between true functions and sampled functions, where the numbers in the parentheses denotes the standard deviations.\"\n",
    ")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.9.13 ('base')",
   "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.13"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "c6e4e9f98eb68ad3b7c296f83d20e6de614cb42e90992a65aa266555a3137d0d"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
