{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5d289e4e-8334-4cbd-9b3e-0eef2ab5fc9e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "%reload_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7363774a-08a1-4536-bce0-19ffb9415952",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import json\n",
    "import logging\n",
    "import typing as ty\n",
    "from IPython.display import display, HTML, Markdown, display_html\n",
    "from pathlib import Path\n",
    "from typing import Dict, List, Optional\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "\n",
    "import egr.pandas_helpers as ph\n",
    "import nb.reports.helpers as hlp\n",
    "import nb.reports.vis_helpers as vh\n",
    "from egr.util import load_graph\n",
    "from egr.log import init_logging\n",
    "\n",
    "LOG = logging.getLogger('report')\n",
    "\n",
    "init_logging(level_name='info')\n",
    "pd.set_option('display.precision', 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4b850c0a-816e-4da8-b0ee-29927c246684",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# RUN_ID: str = '230718-02'\n",
    "# VARIANT: str = 'p008-02'\n",
    "NUM_FOLDS: int = 10\n",
    "SAMPLES = ['0002']\n",
    "\n",
    "all_samples = [f'{i:04d}' for i in range(1, 6)]\n",
    "# control_rounds = ['rL', 'rP4', 'rR']\n",
    "control_rounds = ['rR']\n",
    "eegl_rounds = [f'r{i}' for i in range(7)]\n",
    "all_rounds = control_rounds + eegl_rounds\n",
    "data_root: Path = Path(f'/data/results')\n",
    "# exp_root: Path = data_root / RUN_ID\n",
    "# fsg_args = dict(run_id=RUN_ID, tags=eegl_rounds)\n",
    "num_features: int = 10\n",
    "ncols: int = num_features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f77a992e-4965-4bf6-802b-0739a2e64785",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from itertools import chain,cycle\n",
    "def display_side_by_side(*args,titles=cycle([''])):\n",
    "    html_str=''\n",
    "    for df,title in zip(args, chain(titles,cycle(['</br>'])) ):\n",
    "        html_str+='<th style=\"text-align:center\"><td style=\"vertical-align:top\">'\n",
    "        html_str+=f'<h2 style=\"text-align: center;\">{title}</h2>'\n",
    "        html_str+=df.to_html().replace('table','table style=\"display:inline\"')\n",
    "        html_str+='</td></th>'\n",
    "    display_html(html_str,raw=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "db138484-d6e9-41ae-9a5d-9517764f1fac",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>\n",
       ".output {\n",
       "    flex-direction: row;\n",
       "}\n",
       "\n",
       "h1 {\n",
       "    align-text: center;\n",
       "}\n",
       "</style>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "CSS = \"\"\"\n",
    ".output {\n",
    "    flex-direction: row;\n",
    "}\n",
    "\n",
    "h1 {\n",
    "    align-text: center;\n",
    "}\n",
    "\"\"\"\n",
    "\n",
    "HTML('<style>{}</style>'.format(CSS))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "e723e641-4b20-4991-9e3e-618475c6b18f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/markdown": [
       "# <center>F1-Score All</center>"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "---"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "### With Standard Error of Mean"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>4</th>\n",
       "      <th>5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Random</th>\n",
       "      <td>96.12 $\\pm$ 0.89</td>\n",
       "      <td>94.35 $\\pm$ 1.00</td>\n",
       "      <td>95.39 $\\pm$ 0.57</td>\n",
       "      <td>94.52 $\\pm$ 1.31</td>\n",
       "      <td>95.76 $\\pm$ 0.80</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>(Vanilla) Round-0</th>\n",
       "      <td>58.16 $\\pm$ 1.12</td>\n",
       "      <td>60.05 $\\pm$ 1.20</td>\n",
       "      <td>60.02 $\\pm$ 0.75</td>\n",
       "      <td>59.61 $\\pm$ 1.36</td>\n",
       "      <td>58.23 $\\pm$ 0.70</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-1</th>\n",
       "      <td>73.71 $\\pm$ 4.37</td>\n",
       "      <td>75.31 $\\pm$ 5.51</td>\n",
       "      <td>75.13 $\\pm$ 3.83</td>\n",
       "      <td>68.06 $\\pm$ 4.53</td>\n",
       "      <td>64.91 $\\pm$ 4.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-2</th>\n",
       "      <td>85.71 $\\pm$ 5.44</td>\n",
       "      <td>77.45 $\\pm$ 6.01</td>\n",
       "      <td>77.51 $\\pm$ 5.53</td>\n",
       "      <td>89.40 $\\pm$ 5.23</td>\n",
       "      <td>78.31 $\\pm$ 5.67</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-3</th>\n",
       "      <td>94.33 $\\pm$ 3.14</td>\n",
       "      <td>87.76 $\\pm$ 4.46</td>\n",
       "      <td>84.56 $\\pm$ 5.41</td>\n",
       "      <td>92.05 $\\pm$ 4.79</td>\n",
       "      <td>91.69 $\\pm$ 4.56</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-4</th>\n",
       "      <td>97.31 $\\pm$ 2.07</td>\n",
       "      <td>91.76 $\\pm$ 3.73</td>\n",
       "      <td>92.40 $\\pm$ 4.02</td>\n",
       "      <td>91.33 $\\pm$ 5.35</td>\n",
       "      <td>94.60 $\\pm$ 4.54</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-5</th>\n",
       "      <td>96.66 $\\pm$ 2.49</td>\n",
       "      <td>92.75 $\\pm$ 4.50</td>\n",
       "      <td>94.28 $\\pm$ 3.34</td>\n",
       "      <td>91.35 $\\pm$ 5.22</td>\n",
       "      <td>95.39 $\\pm$ 3.88</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-6</th>\n",
       "      <td>95.63 $\\pm$ 2.53</td>\n",
       "      <td>96.69 $\\pm$ 2.44</td>\n",
       "      <td>99.01 $\\pm$ 0.26</td>\n",
       "      <td>91.66 $\\pm$ 5.13</td>\n",
       "      <td>99.22 $\\pm$ 0.29</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                  1                 2                 3   \n",
       "Random             96.12 $\\pm$ 0.89  94.35 $\\pm$ 1.00  95.39 $\\pm$ 0.57  \\\n",
       "(Vanilla) Round-0  58.16 $\\pm$ 1.12  60.05 $\\pm$ 1.20  60.02 $\\pm$ 0.75   \n",
       "Round-1            73.71 $\\pm$ 4.37  75.31 $\\pm$ 5.51  75.13 $\\pm$ 3.83   \n",
       "Round-2            85.71 $\\pm$ 5.44  77.45 $\\pm$ 6.01  77.51 $\\pm$ 5.53   \n",
       "Round-3            94.33 $\\pm$ 3.14  87.76 $\\pm$ 4.46  84.56 $\\pm$ 5.41   \n",
       "Round-4            97.31 $\\pm$ 2.07  91.76 $\\pm$ 3.73  92.40 $\\pm$ 4.02   \n",
       "Round-5            96.66 $\\pm$ 2.49  92.75 $\\pm$ 4.50  94.28 $\\pm$ 3.34   \n",
       "Round-6            95.63 $\\pm$ 2.53  96.69 $\\pm$ 2.44  99.01 $\\pm$ 0.26   \n",
       "\n",
       "                                  4                 5  \n",
       "Random             94.52 $\\pm$ 1.31  95.76 $\\pm$ 0.80  \n",
       "(Vanilla) Round-0  59.61 $\\pm$ 1.36  58.23 $\\pm$ 0.70  \n",
       "Round-1            68.06 $\\pm$ 4.53  64.91 $\\pm$ 4.68  \n",
       "Round-2            89.40 $\\pm$ 5.23  78.31 $\\pm$ 5.67  \n",
       "Round-3            92.05 $\\pm$ 4.79  91.69 $\\pm$ 4.56  \n",
       "Round-4            91.33 $\\pm$ 5.35  94.60 $\\pm$ 4.54  \n",
       "Round-5            91.35 $\\pm$ 5.22  95.39 $\\pm$ 3.88  \n",
       "Round-6            91.66 $\\pm$ 5.13  99.22 $\\pm$ 0.29  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "### With Standard Deviation"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>1</th>\n",
       "      <th>2</th>\n",
       "      <th>3</th>\n",
       "      <th>4</th>\n",
       "      <th>5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Random</th>\n",
       "      <td>96.12 $\\pm$ 2.66</td>\n",
       "      <td>94.35 $\\pm$ 3.00</td>\n",
       "      <td>95.39 $\\pm$ 1.71</td>\n",
       "      <td>94.52 $\\pm$ 3.92</td>\n",
       "      <td>95.76 $\\pm$ 2.39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>(Vanilla) Round-0</th>\n",
       "      <td>58.16 $\\pm$ 3.37</td>\n",
       "      <td>60.05 $\\pm$ 3.59</td>\n",
       "      <td>60.02 $\\pm$ 2.24</td>\n",
       "      <td>59.61 $\\pm$ 4.07</td>\n",
       "      <td>58.23 $\\pm$ 2.09</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-1</th>\n",
       "      <td>73.71 $\\pm$ 13.10</td>\n",
       "      <td>75.31 $\\pm$ 16.54</td>\n",
       "      <td>75.13 $\\pm$ 11.49</td>\n",
       "      <td>68.06 $\\pm$ 13.60</td>\n",
       "      <td>64.91 $\\pm$ 14.05</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-2</th>\n",
       "      <td>85.71 $\\pm$ 16.31</td>\n",
       "      <td>77.45 $\\pm$ 18.03</td>\n",
       "      <td>77.51 $\\pm$ 16.60</td>\n",
       "      <td>89.40 $\\pm$ 15.70</td>\n",
       "      <td>78.31 $\\pm$ 17.01</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-3</th>\n",
       "      <td>94.33 $\\pm$ 9.43</td>\n",
       "      <td>87.76 $\\pm$ 13.37</td>\n",
       "      <td>84.56 $\\pm$ 16.24</td>\n",
       "      <td>92.05 $\\pm$ 14.37</td>\n",
       "      <td>91.69 $\\pm$ 13.67</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-4</th>\n",
       "      <td>97.31 $\\pm$ 6.22</td>\n",
       "      <td>91.76 $\\pm$ 11.18</td>\n",
       "      <td>92.40 $\\pm$ 12.05</td>\n",
       "      <td>91.33 $\\pm$ 16.05</td>\n",
       "      <td>94.60 $\\pm$ 13.61</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-5</th>\n",
       "      <td>96.66 $\\pm$ 7.46</td>\n",
       "      <td>92.75 $\\pm$ 13.49</td>\n",
       "      <td>94.28 $\\pm$ 10.01</td>\n",
       "      <td>91.35 $\\pm$ 15.67</td>\n",
       "      <td>95.39 $\\pm$ 11.63</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-6</th>\n",
       "      <td>95.63 $\\pm$ 7.60</td>\n",
       "      <td>96.69 $\\pm$ 7.33</td>\n",
       "      <td>99.01 $\\pm$ 0.79</td>\n",
       "      <td>91.66 $\\pm$ 15.39</td>\n",
       "      <td>99.22 $\\pm$ 0.87</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                   1                  2                  3   \n",
       "Random              96.12 $\\pm$ 2.66   94.35 $\\pm$ 3.00   95.39 $\\pm$ 1.71  \\\n",
       "(Vanilla) Round-0   58.16 $\\pm$ 3.37   60.05 $\\pm$ 3.59   60.02 $\\pm$ 2.24   \n",
       "Round-1            73.71 $\\pm$ 13.10  75.31 $\\pm$ 16.54  75.13 $\\pm$ 11.49   \n",
       "Round-2            85.71 $\\pm$ 16.31  77.45 $\\pm$ 18.03  77.51 $\\pm$ 16.60   \n",
       "Round-3             94.33 $\\pm$ 9.43  87.76 $\\pm$ 13.37  84.56 $\\pm$ 16.24   \n",
       "Round-4             97.31 $\\pm$ 6.22  91.76 $\\pm$ 11.18  92.40 $\\pm$ 12.05   \n",
       "Round-5             96.66 $\\pm$ 7.46  92.75 $\\pm$ 13.49  94.28 $\\pm$ 10.01   \n",
       "Round-6             95.63 $\\pm$ 7.60   96.69 $\\pm$ 7.33   99.01 $\\pm$ 0.79   \n",
       "\n",
       "                                   4                  5  \n",
       "Random              94.52 $\\pm$ 3.92   95.76 $\\pm$ 2.39  \n",
       "(Vanilla) Round-0   59.61 $\\pm$ 4.07   58.23 $\\pm$ 2.09  \n",
       "Round-1            68.06 $\\pm$ 13.60  64.91 $\\pm$ 14.05  \n",
       "Round-2            89.40 $\\pm$ 15.70  78.31 $\\pm$ 17.01  \n",
       "Round-3            92.05 $\\pm$ 14.37  91.69 $\\pm$ 13.67  \n",
       "Round-4            91.33 $\\pm$ 16.05  94.60 $\\pm$ 13.61  \n",
       "Round-5            91.35 $\\pm$ 15.67  95.39 $\\pm$ 11.63  \n",
       "Round-6            91.66 $\\pm$ 15.39   99.22 $\\pm$ 0.87  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def show(var: str, run_id: str, samples: ty.List[str], n_folds: int = 10):\n",
    "    exp_root = data_root / run_id\n",
    "    def mk_table(fold) -> pd.DataFrame:\n",
    "        return hlp.make_table(exp_root, samples, var, all_rounds, fold)\n",
    "\n",
    "    tables = [mk_table(fold + 1) for fold in range(n_folds)]\n",
    "    arrays = [df.to_numpy() for df in tables]\n",
    "\n",
    "    mean_df = ph.mean_df(tables)\n",
    "    sem = stats.sem(arrays, axis=0)\n",
    "    std = np.std(arrays, axis=0)\n",
    "\n",
    "    spec = hlp.get_variant_spec(var)\n",
    "    # display(Markdown(f'## <center>{spec.name}</center>'))\n",
    "    # display(Markdown(f'### <center>{spec.desc}: Folds: {n_folds}</center>'))\n",
    "    sem_df = pd.DataFrame(index=mean_df.index, columns=mean_df.columns)\n",
    "    sem_df_styler = sem_df.style.set_table_attributes(\"style='display:inline'\").set_caption('Standard Error of Mean')\n",
    "    \n",
    "    for r in range(mean_df.shape[0]):\n",
    "        for c in range(mean_df.shape[1]):\n",
    "            sem_df.iloc[r, c] = f'{mean_df.iloc[r, c]:.2f} $\\pm$ {sem[r, c]:.2f}'\n",
    "    \n",
    "    std_df = pd.DataFrame(index=mean_df.index, columns=mean_df.columns)\n",
    "    std_df_styler = std_df.style.set_table_attributes(\"style='display:inline'\").set_caption('Standard Deviation')\n",
    "    for r in range(mean_df.shape[0]):\n",
    "        for c in range(mean_df.shape[1]):\n",
    "            std_df.iloc[r, c] = f'{mean_df.iloc[r, c]:.2f} $\\pm$ {std[r, c]:.2f}'\n",
    "    \n",
    "    # display_side_by_side(sem_df, std_df, titles=['$\\pm$ SEM', '(STDDEV)'])\n",
    "    # HTML('<style>.output {flex-direction: row;}</style>')\n",
    "    # # display(sem_df)\n",
    "    # # display(std_df)\n",
    "    # display_html(sem_df_styler._repr_html_() + std_df_styler._repr_html_(), raw=True)\n",
    "    # display(Markdown('---'))\n",
    "    \n",
    "    return sem_df['F1-Score'], std_df['F1-Score']\n",
    "    \n",
    "display(Markdown('# <center>F1-Score All</center>'))\n",
    "display(Markdown('---'))\n",
    "\n",
    "variants = [\n",
    "    # ('p001-01', ['0001'], 10),\n",
    "    # ('p001-02', ['0001'], 10),\n",
    "    # ('p001-03', ['0001'], 10),\n",
    "    # ('p007-02', ['0001'], 10),\n",
    "    # ('p008-02', ['0001'], 10),\n",
    "    ('p009-02', ['0002'], 10),\n",
    "]\n",
    "\n",
    "iterations = [\n",
    "    ('1', '230718-01'),\n",
    "    ('2', '230718-02'),\n",
    "    ('3', '230718-03'),\n",
    "    ('4', '230718-04'),\n",
    "    ('5', '230718-05')\n",
    "]\n",
    "\n",
    "# columns=[hlp.get_variant_spec(v[0]).name for v in variants]\n",
    "columns = [idx for idx, _ in iterations]\n",
    "df_sem, df_std = pd.DataFrame(columns=columns), pd.DataFrame(columns=columns)\n",
    "for variant, samples, folds in variants:\n",
    "    for idx, name in iterations:\n",
    "        df_m, df_sd = show(variant, name, samples, n_folds=folds)\n",
    "        # df_sem[hlp.get_variant_spec(variant).name] = df_m\n",
    "        # df_std[hlp.get_variant_spec(variant).name] = df_sd\n",
    "        df_sem[str(idx)] = df_m\n",
    "        df_std[str(idx)] = df_sd\n",
    "    \n",
    "# df_sem.style.highlight_max(color='lightgreen', axis=0)\n",
    "display(Markdown('### With Standard Error of Mean'))\n",
    "display(df_sem)\n",
    "\n",
    "display(Markdown('### With Standard Deviation'))\n",
    "# df_std.style.format(':.2f').to_latex(caption='SD', hrules=True)\n",
    "display(df_std)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "c54ab1f1-2b9d-4260-96b3-89a90ed8b176",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>$M_{2}^{\"}$</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Random</th>\n",
       "      <td>95.23 $\\pm$ 0.77</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>(Vanilla) Round-0</th>\n",
       "      <td>59.21 $\\pm$ 0.95</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-1</th>\n",
       "      <td>71.42 $\\pm$ 4.68</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-2</th>\n",
       "      <td>81.68 $\\pm$ 5.54</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-3</th>\n",
       "      <td>90.08 $\\pm$ 3.89</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-4</th>\n",
       "      <td>93.48 $\\pm$ 2.49</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-5</th>\n",
       "      <td>94.09 $\\pm$ 2.10</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Round-6</th>\n",
       "      <td>96.44 $\\pm$ 3.08</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                        $M_{2}^{\"}$\n",
       "Random             95.23 $\\pm$ 0.77\n",
       "(Vanilla) Round-0  59.21 $\\pm$ 0.95\n",
       "Round-1            71.42 $\\pm$ 4.68\n",
       "Round-2            81.68 $\\pm$ 5.54\n",
       "Round-3            90.08 $\\pm$ 3.89\n",
       "Round-4            93.48 $\\pm$ 2.49\n",
       "Round-5            94.09 $\\pm$ 2.10\n",
       "Round-6            96.44 $\\pm$ 3.08"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def make_ave_table(var: str, run_id: str, samples: ty.List[str], n_folds: int = 10):\n",
    "    exp_root = data_root / run_id\n",
    "    def mk_table(fold) -> pd.DataFrame:\n",
    "        return hlp.make_table(exp_root, samples, var, all_rounds, fold)\n",
    "    tables = [mk_table(fold + 1) for fold in range(n_folds)]\n",
    "    arrays = [df.to_numpy() for df in tables]\n",
    "    mean_df = ph.mean_df(tables)\n",
    "    return mean_df['F1-Score']\n",
    "\n",
    "all_df = pd.DataFrame()\n",
    "for idx, iter in iterations:\n",
    "    mean_df = make_ave_table(\n",
    "        'p009-02', \n",
    "        iter,\n",
    "        samples=['0002'], \n",
    "        n_folds=10)\n",
    "    all_df[idx] = mean_df\n",
    "\n",
    "ave_df, std_df = all_df.mean(axis=1), all_df.std(axis=1)\n",
    "final_df = pd.DataFrame(index=ave_df.index, columns=['$M_{2}^{\"}$'])\n",
    "\n",
    "for r in range(ave_df.shape[0]):\n",
    "    final_df.iloc[r, 0] = f'{ave_df[r]:.2f} $\\pm$ {std_df[r]:.2f}'\n",
    "\n",
    "# print(final_df.to_latex())\n",
    "display(final_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "27dfc755-f866-4846-b240-79497ea77b38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Random               95.23\n",
       "(Vanilla) Round-0    59.21\n",
       "Round-1              71.42\n",
       "Round-2              81.68\n",
       "Round-3              90.08\n",
       "Round-4              93.48\n",
       "Round-5              94.09\n",
       "Round-6              96.44\n",
       "dtype: float64"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display(multi_mean_df.mean(axis=1))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8243bc55-d15f-4083-9109-c2dc4d732079",
   "metadata": {},
   "source": [
    "[<< All Reports](http://pods.evl.uic.edu/eegl/230510/main.html)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "52cc5ebf-193f-462d-895e-5b68bb930465",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Random               0.77\n",
       "(Vanilla) Round-0    0.95\n",
       "Round-1              4.68\n",
       "Round-2              5.54\n",
       "Round-3              3.89\n",
       "Round-4              2.49\n",
       "Round-5              2.10\n",
       "Round-6              3.08\n",
       "dtype: float64"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display(multi_mean_df.std(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "700246ad-8cea-464d-ab9f-12df4de97a71",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
