{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import product\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiment parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Number of time windows\n",
    "T = 18\n",
    "\n",
    "# Target 1-coverage for conformal prediction\n",
    "alpha = 0.1\n",
    "\n",
    "data_name=\"School\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "methods = ['BD', 'UA']\n",
    "GNN_models = ['GCN', 'GAT']\n",
    "regimes = ['Assisted Semi-Ind', 'Trans', 'Semi-Ind']\n",
    "# regimes = ['Trans', 'Semi-Ind']\n",
    "outputs = ['Accuracy', 'Avg Size', 'Coverage']\n",
    "\n",
    "xlabels = ['', '10am', '', '12pm', '\\nDay 1', '2pm', '', '4pm', '',\n",
    "        '', '10am', '', '12pm', '\\nDay 2', '2pm', '', '4pm', '']\n",
    "\n",
    "def get_summary(score_function):\n",
    "    results_file = f'results/School_{score_function}.pkl'\n",
    "\n",
    "    with open(results_file, 'rb') as file:\n",
    "        results = pickle.load(file)\n",
    "\n",
    "    methods_list = []\n",
    "    GNN_models_list = []\n",
    "    regimes_list = []\n",
    "    outputs_list = []\n",
    "    stat_types_list = []\n",
    "    stats_list = []\n",
    "\n",
    "    for (method, GNN_model, regime, output) in product(methods, GNN_models, regimes, outputs):\n",
    "\n",
    "        methods_list.append(method)\n",
    "        GNN_models_list.append(GNN_model)\n",
    "        regimes_list.append(regime)\n",
    "        outputs_list.append(output)\n",
    "        stat_types_list.append('Mean')\n",
    "        stats_list.append(np.round(np.mean(results[method][GNN_model][regime][output]['All']), 3))\n",
    "        \n",
    "        methods_list.append(method)\n",
    "        GNN_models_list.append(GNN_model)\n",
    "        regimes_list.append(regime)\n",
    "        outputs_list.append(output)\n",
    "        stat_types_list.append('St Dev')\n",
    "        stats_list.append(np.round(np.std(results[method][GNN_model][regime][output]['All']), 3))\n",
    "        \n",
    "    output = \"TSC\"\n",
    "    for (method, GNN_model, regime) in product(methods, GNN_models, regimes):\n",
    "        # if regime == \"Semi-Ind\":\n",
    "        #     num_vals = 50\n",
    "        # elif regime in [\"Assisted Semi-Ind\", \"Assisted Semi-Ind\"]:\n",
    "        #     # num_vals = 1000\n",
    "\n",
    "        num_vals = len(results[method][GNN_model][regime]['Coverage']['All'])\n",
    "\n",
    "        T_output = np.where(np.array([len(results[method][GNN_model][regime][\"Coverage\"][t]) for t in range(T)]) > 0)[0]\n",
    "\n",
    "\n",
    "        covs = np.zeros((T, num_vals))\n",
    "        for t in T_output:\n",
    "            covs[t] = results[method][GNN_model][regime][\"Coverage\"][t]\n",
    "\n",
    "        # min_covs = []\n",
    "        # for cov_run in range(num_vals):\n",
    "        #     covs_for_run = covs[:, cov_run]\n",
    "        #     covs_for_run = covs_for_run[covs_for_run > 0]\n",
    "        #     min_covs.append(np.min(covs_for_run))\n",
    "\n",
    "        TSC = []\n",
    "        for t in T_output:\n",
    "            TSC.append(np.mean(covs[t, :]))\n",
    "\n",
    "        min_TSC_idx = np.argmin(TSC)\n",
    "        min_TSC = TSC[min_TSC_idx]\n",
    "        std_min_TSC = np.std(covs[T_output[min_TSC_idx], :])\n",
    "\n",
    "\n",
    "        methods_list.append(method)\n",
    "        GNN_models_list.append(GNN_model)\n",
    "        regimes_list.append(regime)\n",
    "        outputs_list.append(output)\n",
    "        stat_types_list.append('Mean')\n",
    "        stats_list.append(np.round(min_TSC, 3))\n",
    "\n",
    "        methods_list.append(method)\n",
    "        GNN_models_list.append(GNN_model)\n",
    "        regimes_list.append(regime)\n",
    "        outputs_list.append(output)\n",
    "        stat_types_list.append('St Dev')\n",
    "        stats_list.append(np.round(std_min_TSC, 3)) \n",
    "\n",
    "\n",
    "    df_summary = pd.DataFrame({\n",
    "        'method'   : methods_list,\n",
    "        'GNN model': GNN_models_list,\n",
    "        'regime'   : regimes_list,\n",
    "        'output'   : outputs_list,\n",
    "        'statistic': stat_types_list,\n",
    "        'value'    : stats_list,\n",
    "        'score_function': score_function\n",
    "    })\n",
    "    return df_summary\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Display full table of statistics."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   method GNN model             regime    output statistic  value  \\\n",
      "0      BD       GCN  Assisted Semi-Ind  Accuracy      Mean  0.117   \n",
      "1      BD       GCN  Assisted Semi-Ind  Accuracy    St Dev  0.010   \n",
      "2      BD       GCN  Assisted Semi-Ind  Avg Size      Mean  9.121   \n",
      "3      BD       GCN  Assisted Semi-Ind  Avg Size    St Dev  0.254   \n",
      "4      BD       GCN  Assisted Semi-Ind  Coverage      Mean  0.913   \n",
      "..    ...       ...                ...       ...       ...    ...   \n",
      "91     UA       GAT  Assisted Semi-Ind       TSC    St Dev  0.052   \n",
      "92     UA       GAT              Trans       TSC      Mean  0.798   \n",
      "93     UA       GAT              Trans       TSC    St Dev  0.070   \n",
      "94     UA       GAT           Semi-Ind       TSC      Mean  0.848   \n",
      "95     UA       GAT           Semi-Ind       TSC    St Dev  0.060   \n",
      "\n",
      "   score_function  \n",
      "0             APS  \n",
      "1             APS  \n",
      "2             APS  \n",
      "3             APS  \n",
      "4             APS  \n",
      "..            ...  \n",
      "91            APS  \n",
      "92            APS  \n",
      "93            APS  \n",
      "94            APS  \n",
      "95            APS  \n",
      "\n",
      "[96 rows x 7 columns]\n"
     ]
    }
   ],
   "source": [
    "df_summary = get_summary(\"APS\")\n",
    "print(df_summary)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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>method</th>\n",
       "      <th>GNN model</th>\n",
       "      <th>regime</th>\n",
       "      <th>output</th>\n",
       "      <th>statistic</th>\n",
       "      <th>value</th>\n",
       "      <th>score_function</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.913</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.024</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.901</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.012</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.821</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>BD</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.049</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.922</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.027</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.901</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.012</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.665</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>BD</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.097</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.902</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.016</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.901</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.012</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.889</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>UA</td>\n",
       "      <td>GCN</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.020</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.903</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Assisted Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.016</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>64</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.901</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>65</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Trans</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.012</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>70</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>Mean</td>\n",
       "      <td>0.907</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>71</th>\n",
       "      <td>UA</td>\n",
       "      <td>GAT</td>\n",
       "      <td>Semi-Ind</td>\n",
       "      <td>Coverage</td>\n",
       "      <td>St Dev</td>\n",
       "      <td>0.023</td>\n",
       "      <td>APS</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   method GNN model             regime    output statistic  value  \\\n",
       "4      BD       GCN  Assisted Semi-Ind  Coverage      Mean  0.913   \n",
       "5      BD       GCN  Assisted Semi-Ind  Coverage    St Dev  0.024   \n",
       "10     BD       GCN              Trans  Coverage      Mean  0.901   \n",
       "11     BD       GCN              Trans  Coverage    St Dev  0.012   \n",
       "16     BD       GCN           Semi-Ind  Coverage      Mean  0.821   \n",
       "17     BD       GCN           Semi-Ind  Coverage    St Dev  0.049   \n",
       "22     BD       GAT  Assisted Semi-Ind  Coverage      Mean  0.922   \n",
       "23     BD       GAT  Assisted Semi-Ind  Coverage    St Dev  0.027   \n",
       "28     BD       GAT              Trans  Coverage      Mean  0.901   \n",
       "29     BD       GAT              Trans  Coverage    St Dev  0.012   \n",
       "34     BD       GAT           Semi-Ind  Coverage      Mean  0.665   \n",
       "35     BD       GAT           Semi-Ind  Coverage    St Dev  0.097   \n",
       "40     UA       GCN  Assisted Semi-Ind  Coverage      Mean  0.902   \n",
       "41     UA       GCN  Assisted Semi-Ind  Coverage    St Dev  0.016   \n",
       "46     UA       GCN              Trans  Coverage      Mean  0.901   \n",
       "47     UA       GCN              Trans  Coverage    St Dev  0.012   \n",
       "52     UA       GCN           Semi-Ind  Coverage      Mean  0.889   \n",
       "53     UA       GCN           Semi-Ind  Coverage    St Dev  0.020   \n",
       "58     UA       GAT  Assisted Semi-Ind  Coverage      Mean  0.903   \n",
       "59     UA       GAT  Assisted Semi-Ind  Coverage    St Dev  0.016   \n",
       "64     UA       GAT              Trans  Coverage      Mean  0.901   \n",
       "65     UA       GAT              Trans  Coverage    St Dev  0.012   \n",
       "70     UA       GAT           Semi-Ind  Coverage      Mean  0.907   \n",
       "71     UA       GAT           Semi-Ind  Coverage    St Dev  0.023   \n",
       "\n",
       "   score_function  \n",
       "4             APS  \n",
       "5             APS  \n",
       "10            APS  \n",
       "11            APS  \n",
       "16            APS  \n",
       "17            APS  \n",
       "22            APS  \n",
       "23            APS  \n",
       "28            APS  \n",
       "29            APS  \n",
       "34            APS  \n",
       "35            APS  \n",
       "40            APS  \n",
       "41            APS  \n",
       "46            APS  \n",
       "47            APS  \n",
       "52            APS  \n",
       "53            APS  \n",
       "58            APS  \n",
       "59            APS  \n",
       "64            APS  \n",
       "65            APS  \n",
       "70            APS  \n",
       "71            APS  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_summary[df_summary['output'] == \"Coverage\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "score_functions = [\"APS\", \"RAPS\", \"SAPS\"]\n",
    "df_summaries = [get_summary(score_function) for score_function in score_functions]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{table}[ht]\n",
      "\\centering\n",
      "\n"
     ]
    },
    {
     "ename": "UnboundLocalError",
     "evalue": "local variable 'value' referenced before assignment",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mUnboundLocalError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[18], line 91\u001b[0m\n\u001b[1;32m     87\u001b[0m                 \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mtextbf\u001b[39m\u001b[38;5;130;01m{{\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mvalue\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;130;01m}}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m     89\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m value\n\u001b[0;32m---> 91\u001b[0m     table_data \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mreplace_dict[method]\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mGNN_model\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m & \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mformat_cell(trans_acc,\u001b[38;5;250m \u001b[39mtrans_std)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m & \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mformat_cell(semi_ind_acc,\u001b[38;5;250m \u001b[39msemi_ind_std)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m & \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mformat_cell(temp_trans_acc,\u001b[38;5;250m \u001b[39mtemp_trans_std)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m \u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124m \u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mhline\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m     93\u001b[0m table_str \u001b[38;5;241m=\u001b[39m table_start_str \u001b[38;5;241m+\u001b[39m table_data \u001b[38;5;241m+\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mend\u001b[39m\u001b[38;5;132;01m{tabular}\u001b[39;00m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mcaption\u001b[39m\u001b[38;5;124m{\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;241m+\u001b[39m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00moutput\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m for the \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mdata_name\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m experiment using \u001b[39m\u001b[38;5;132;01m{\u001b[39;00mscore_function\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m.\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;241m+\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m}\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mend\u001b[39m\u001b[38;5;132;01m{subtable}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m     95\u001b[0m \u001b[38;5;28mprint\u001b[39m(table_str)\n",
      "Cell \u001b[0;32mIn[18], line 89\u001b[0m, in \u001b[0;36mformat_cell\u001b[0;34m(mean, std)\u001b[0m\n\u001b[1;32m     86\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m output \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mCoverage\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;129;01mand\u001b[39;00m (mean \u001b[38;5;241m+\u001b[39m std) \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0.9\u001b[39m:\n\u001b[1;32m     87\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[38;5;124mtextbf\u001b[39m\u001b[38;5;130;01m{{\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mvalue\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;130;01m}}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m---> 89\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mvalue\u001b[49m\n",
      "\u001b[0;31mUnboundLocalError\u001b[0m: local variable 'value' referenced before assignment"
     ]
    }
   ],
   "source": [
    "table_start_start_str = \"\\\\begin{table}[ht]\\n\\\\centering\\n\"\n",
    "print(table_start_start_str)\n",
    "for data_idx in range(len(score_functions)):\n",
    "    score_function = score_functions[data_idx]\n",
    "    df_summary = df_summaries[data_idx]\n",
    "\n",
    "    df_summary[\"name\"] = df_summary[\"method\"] + \" \" + df_summary[\"GNN model\"]\n",
    "\n",
    "    replace_dict = {\n",
    "        \"BD\": \"Block \",\n",
    "        \"UA\": \"U\",\n",
    "    }\n",
    "\n",
    "    df_summary[\"name\"] = df_summary[\"name\"].replace(replace_dict)\n",
    "\n",
    "    output = \"Avg Size\"\n",
    "\n",
    "    table_start_str = (\n",
    "        \"\\\\begin{subtable}{\\\\textwidth}\\n\\\\centering\\n\\\\begin{tabular}{|l|l|l|l|}\\n\\\\hline\\nEmbedding & \\\\multicolumn{3}{c|}{\"\n",
    "        + f\"{data_name}\"\n",
    "        + \"} \\\\\\ \\n\\\\cline{2-4}\\n& Trans. & Semi-ind. & Temp. Trans. \\\\\\ \\n\\\\hline\\n\"\n",
    "    )\n",
    "\n",
    "    table_data = \"\"\n",
    "    # Loop over each unique method + regime pair\n",
    "    for (GNN_model, method) in product(GNN_models, methods):\n",
    "\n",
    "        max_trans_acc = df_summary[\n",
    "            (df_summary[\"regime\"] == \"Trans\") & (df_summary[\"output\"] == output) & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        ][\"value\"].max()\n",
    "        max_semi_ind_acc = df_summary[\n",
    "            (df_summary[\"regime\"] == \"Semi-Ind\") & (df_summary[\"output\"] == output) & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        ][\"value\"].max()\n",
    "        max_temp_trans_acc = df_summary[\n",
    "            (df_summary[\"regime\"] == \"Assisted Semi-Ind\") & (df_summary[\"output\"] == output) & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        ][\"value\"].max()\n",
    "\n",
    "        trans_acc = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Trans\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"Mean\")\n",
    "        ][\"value\"].values[0]\n",
    "        trans_std = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Trans\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"St Dev\")\n",
    "        ][\"value\"].values[0]\n",
    "\n",
    "        semi_ind_acc = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Semi-Ind\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"Mean\")\n",
    "        ][\"value\"].values[0]\n",
    "        semi_ind_std = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Semi-Ind\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"St Dev\")\n",
    "        ][\"value\"].values[0]\n",
    "\n",
    "        temp_trans_acc = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Assisted Semi-Ind\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"Mean\")\n",
    "        ][\"value\"].values[0]\n",
    "        temp_trans_std = df_summary[\n",
    "            (df_summary[\"method\"] == method)\n",
    "            & (df_summary[\"GNN model\"] == GNN_model)\n",
    "            & (df_summary[\"regime\"] == \"Assisted Semi-Ind\")\n",
    "            & (df_summary[\"output\"] == output)\n",
    "            & (df_summary[\"statistic\"] == \"St Dev\")\n",
    "        ][\"value\"].values[0]\n",
    "\n",
    "        def format_cell(mean, std):\n",
    "            if output == \"Coverage\":\n",
    "                value = f\"{mean:.3f} $\\\\pm$ {std:.3f}\"\n",
    "                if output == \"Coverage\" and (mean + std) >= 0.9:\n",
    "                    return f\"\\\\textbf{{{value}}}\"\n",
    "\n",
    "            elif output == \"Avg Size\":\n",
    "                value = f\"{mean:.3f} $\\\\pm$ {std:.3f}\"\n",
    "                \n",
    "            return value\n",
    "\n",
    "        table_data += f\"{replace_dict[method]}{GNN_model} & {format_cell(trans_acc, trans_std)} & {format_cell(semi_ind_acc, semi_ind_std)} & {format_cell(temp_trans_acc, temp_trans_std)} \\\\\\\\ \\\\hline\\n\"\n",
    "\n",
    "    table_str = table_start_str + table_data + \"\\\\end{tabular}\\n\\\\caption{\" + f\"{output} for the {data_name} experiment using {score_function}.\" + \"}\\n\\\\end{subtable}\"\n",
    "\n",
    "    print(table_str)\n",
    "    print(\"\")\n",
    "\n",
    "table_end_end_str = \"\\n\\\\caption{}\\n\\\\end{table}\"\n",
    "print(table_end_end_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "index 0 is out of bounds for axis 0 with size 0",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m\n",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)\n",
      "Cell \u001b[0;32mIn[42], line 35\u001b[0m\n",
      "\u001b[1;32m     28\u001b[0m max_trans_acc \u001b[38;5;241m=\u001b[39m df_summary[\n",
      "\u001b[1;32m     29\u001b[0m     (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mregime\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTrans\u001b[39m\u001b[38;5;124m\"\u001b[39m) \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124moutput\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m output) \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mGNN model\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m GNN_model)\n",
      "\u001b[1;32m     30\u001b[0m ][\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mvalue\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39mmax()\n",
      "\u001b[1;32m     31\u001b[0m max_semi_ind_acc \u001b[38;5;241m=\u001b[39m df_summary[\n",
      "\u001b[1;32m     32\u001b[0m     (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mregime\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mSemi-Ind\u001b[39m\u001b[38;5;124m\"\u001b[39m) \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124moutput\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m output) \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mGNN model\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m GNN_model)\n",
      "\u001b[1;32m     33\u001b[0m ][\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mvalue\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39mmax()\n",
      "\u001b[0;32m---> 35\u001b[0m trans_acc \u001b[38;5;241m=\u001b[39m \u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\n",
      "\u001b[1;32m     36\u001b[0m \u001b[43m    \u001b[49m\u001b[43m(\u001b[49m\u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mmethod\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mmethod\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;32m     37\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m&\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mGNN model\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mGNN_model\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;32m     38\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m&\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mregime\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mTrans\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;32m     39\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m&\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43moutput\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[43moutput\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;32m     40\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m&\u001b[39;49m\u001b[43m \u001b[49m\u001b[43m(\u001b[49m\u001b[43mdf_summary\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mstatistic\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m==\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mMean\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n",
      "\u001b[1;32m     41\u001b[0m \u001b[43m\u001b[49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mvalue\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m]\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mvalues\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\n",
      "\u001b[1;32m     42\u001b[0m trans_std \u001b[38;5;241m=\u001b[39m df_summary[\n",
      "\u001b[1;32m     43\u001b[0m     (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmethod\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m method)\n",
      "\u001b[1;32m     44\u001b[0m     \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mGNN model\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m GNN_model)\n",
      "\u001b[0;32m   (...)\u001b[0m\n",
      "\u001b[1;32m     47\u001b[0m     \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mstatistic\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mSt Dev\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[1;32m     48\u001b[0m ][\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mvalue\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39mvalues[\u001b[38;5;241m0\u001b[39m]\n",
      "\u001b[1;32m     49\u001b[0m semi_ind_acc \u001b[38;5;241m=\u001b[39m df_summary[\n",
      "\u001b[1;32m     50\u001b[0m     (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mmethod\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m method)\n",
      "\u001b[1;32m     51\u001b[0m     \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mGNN model\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m GNN_model)\n",
      "\u001b[0;32m   (...)\u001b[0m\n",
      "\u001b[1;32m     54\u001b[0m     \u001b[38;5;241m&\u001b[39m (df_summary[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mstatistic\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m==\u001b[39m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mMean\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[1;32m     55\u001b[0m ][\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mvalue\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39mvalues[\u001b[38;5;241m0\u001b[39m]\n",
      "\n",
      "\u001b[0;31mIndexError\u001b[0m: index 0 is out of bounds for axis 0 with size 0"
     ]
    }
   ],
   "source": [
    "df_summary[\"name\"] = df_summary[\"method\"] + \" \" + df_summary[\"score_function\"]\n",
    "\n",
    "replace_dict = {\n",
    "    \"BD GCN\": \"Block GCN\",\n",
    "    \"BD GAT\": \"Block GAT\",\n",
    "    \"UA GCN\": \"UGCN\",\n",
    "    \"UA GAT\": \"UGAT\",\n",
    "}\n",
    "\n",
    "df_summary[\"name\"] = df_summary[\"name\"].replace(replace_dict)\n",
    "\n",
    "\n",
    "output=\"TSC\"\n",
    "\n",
    "table_start_str = (\n",
    "    \"\\\\begin{table}[h]\\n\\\\centering\\n\\\\begin{tabular}{|l|l|l|}\\n\\\\hline\\nEmbedding & \\\\multicolumn{2}{c|}{\"\n",
    "    + data_name\n",
    "    + \"} \\\\\\ \\n\\\\cline{2-3}\\n& Trans. & Semi-ind.  \\\\\\ \\n\\\\hline\\n\"\n",
    ")\n",
    "\n",
    "# table_data_1 = \"ISE & $0.505 \\\\pm 0.000$ & $0.248 \\\\pm 0.000$ \\\\\\\\ \\\\hline\\n\"\n",
    "\n",
    "\n",
    "table_data = \"\"\n",
    "# Loop over each unique method + regime pair\n",
    "for (GNN_model, method) in product(GNN_models, methods):\n",
    "\n",
    "    max_trans_acc = df_summary[\n",
    "        (df_summary[\"regime\"] == \"Trans\") & (df_summary[\"output\"] == output) & (df_summary[\"GNN model\"] == GNN_model)\n",
    "    ][\"value\"].max()\n",
    "    max_semi_ind_acc = df_summary[\n",
    "        (df_summary[\"regime\"] == \"Semi-Ind\") & (df_summary[\"output\"] == output) & (df_summary[\"GNN model\"] == GNN_model)\n",
    "    ][\"value\"].max()\n",
    "\n",
    "    trans_acc = df_summary[\n",
    "        (df_summary[\"method\"] == method)\n",
    "        & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        & (df_summary[\"regime\"] == \"Trans\")\n",
    "        & (df_summary[\"output\"] == output)\n",
    "        & (df_summary[\"statistic\"] == \"Mean\")\n",
    "    ][\"value\"].values[0]\n",
    "    trans_std = df_summary[\n",
    "        (df_summary[\"method\"] == method)\n",
    "        & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        & (df_summary[\"regime\"] == \"Trans\")\n",
    "        & (df_summary[\"output\"] == output)\n",
    "        & (df_summary[\"statistic\"] == \"St Dev\")\n",
    "    ][\"value\"].values[0]\n",
    "    semi_ind_acc = df_summary[\n",
    "        (df_summary[\"method\"] == method)\n",
    "        & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        & (df_summary[\"regime\"] == \"Semi-Ind\")\n",
    "        & (df_summary[\"output\"] == output)\n",
    "        & (df_summary[\"statistic\"] == \"Mean\")\n",
    "    ][\"value\"].values[0]\n",
    "    semi_ind_std = df_summary[\n",
    "        (df_summary[\"method\"] == method)\n",
    "        & (df_summary[\"GNN model\"] == GNN_model)\n",
    "        & (df_summary[\"regime\"] == \"Semi-Ind\")\n",
    "        & (df_summary[\"output\"] == output)\n",
    "        & (df_summary[\"statistic\"] == \"St Dev\")\n",
    "    ][\"value\"].values[0]\n",
    "\n",
    "    method_name = df_summary[\n",
    "        (df_summary[\"method\"] == method)\n",
    "        & (df_summary[\"GNN model\"] == GNN_model)\n",
    "    ][\"name\"].values[0]\n",
    "    \n",
    "\n",
    "    if trans_acc != max_trans_acc:\n",
    "        table_data += f\"{method_name} & {trans_acc:.3f} $\\\\pm$ {trans_std:.3f}\"\n",
    "    else:\n",
    "        table_data += (\n",
    "            method_name + \" & \\\\textbf{\" + f\"{trans_acc:.3f} $\\\\pm$ {trans_std:.3f}\" + \"}\"\n",
    "        )\n",
    "\n",
    "    if semi_ind_acc != max_semi_ind_acc:\n",
    "        table_data += f\" & ${semi_ind_acc:.3f} \\\\pm {semi_ind_std:.3f}$ \\\\\\\\ \\\\hline\\n\"\n",
    "    else:\n",
    "        table_data += (\n",
    "            \" & \\\\textbf{\"\n",
    "            + f\"{semi_ind_acc:.3f} $\\\\pm$ {semi_ind_std:.3f}\"\n",
    "            + \"} \\\\\\\\ \\\\hline\\n\"\n",
    "        )\n",
    "\n",
    "table_end_str = (\n",
    "    \"\\\\end{tabular}\\n\\\\caption{}\\n\\\\label{tab:\"\n",
    "    + data_name\n",
    "    + \"_\"+output+\"}\\n\\\\end{table}\"\n",
    ")\n",
    "\n",
    "full_table = table_start_str + table_data + table_end_str\n",
    "\n",
    "print(full_table)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "TGB_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.10.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
