{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "69746215",
   "metadata": {},
   "source": [
    "## Table Aggregation: BGP Synthesis Time\n",
    "\n",
    "In this notebook we aggregate the raw data into tables on BGP/OSPF synthesis time as used in our figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "22dcb06c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "def get_neural_files(basedir): return dict([[int(f.split(\"-\")[2]), basedir + f] for f in os.listdir(basedir) if f.startswith(\"bgp-reqs\")])\n",
    "neural_files = get_neural_files(\"results/\")\n",
    "nc_files = dict([[int(f.split(\"-\")[2][:-len(\"result\")]), \"./netcomplete/results/\" + f] for f in os.listdir(\"./netcomplete/results/\") if f.startswith(\"bgp-reqs\")])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "09d2a39c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "29c0f457",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                 time  num_timeouts  samples  min_nodes  max_nodes    time-std\n",
      "bucket                                                                        \n",
      "0 Small     18.072854             0        8          0          7   14.545376\n",
      "1 Medium    60.864079             0        8          8         15   33.394428\n",
      "2 Large   1389.484829             7        8         16         23  312.584108\n"
     ]
    }
   ],
   "source": [
    "TIMEOUT_VALUE = 999\n",
    "\n",
    "def read_results_file(f, with_consistency=False):\n",
    "    df = pd.read_csv(f, sep=\";\", names=[\"prefix\", \"time\"] + ([\"consistency\"] if with_consistency else []))\n",
    "    \n",
    "    df[\"num_nodes\"] = [int(p[len(\"bgp-n\"):]) for p in df[\"prefix\"].values]\n",
    "    num_samples_per_category = 8\n",
    "    \n",
    "    def bucket(n):\n",
    "        if n < num_samples_per_category: return \"0 Small\"\n",
    "        if n < num_samples_per_category*2: return \"1 Medium\"\n",
    "        return \"2 Large\"\n",
    "    df[\"bucket\"] = [bucket(n) for n in df[\"num_nodes\"]]\n",
    "    \n",
    "    df_with_timeouts = pd.DataFrame(df)\n",
    "    df_with_timeouts[\"num_timeouts\"] = df[\"time\"].values == TIMEOUT_VALUE\n",
    "    \n",
    "    #df = df[df[\"time\"] != 999]\n",
    "    df[\"time\"] = (df[\"time\"] == TIMEOUT_VALUE) * 1500 + (df[\"time\"] != TIMEOUT_VALUE) * df[\"time\"]\n",
    "    \n",
    "    if with_consistency:\n",
    "        df[\"full_match\"] = df[\"consistency\"].values == 1.0\n",
    "    \n",
    "    counts = df.groupby(\"bucket\").count()[\"num_nodes\"]\n",
    "    res = df.groupby(\"bucket\").mean()\n",
    "    std = df.groupby(\"bucket\").std()\n",
    "    del res[\"num_nodes\"]\n",
    "    \n",
    "    if with_consistency:\n",
    "        res[\"consistency-std\"] = std[\"consistency\"]\n",
    "\n",
    "    res[\"samples\"] = counts\n",
    "    res[\"min_nodes\"] = df.groupby(\"bucket\").min()[\"num_nodes\"]\n",
    "    res[\"max_nodes\"] = df.groupby(\"bucket\").max()[\"num_nodes\"]\n",
    "    res[\"num_timeouts\"] = df_with_timeouts.groupby(\"bucket\").sum()[\"num_timeouts\"]\n",
    "    res[\"time-std\"] = std[\"time\"]\n",
    "    \n",
    "    return res\n",
    "#print(read_results_file(\"bgp/neural/bgp-reqs-2-result-bgp-2021-09-15_11:25:18.csv\", with_consistency=True))\n",
    "print(read_results_file(nc_files[2]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a7ec01d3",
   "metadata": {},
   "outputs": [],
   "source": [
    "system_name = \"Neural\"\n",
    "consistency_col = \"Consistency (Neural)\"\n",
    "full_match_col = \"Full Match (Neural)\"\n",
    "\n",
    "def merge(df_netcomplete, df_neural):\n",
    "    res = pd.DataFrame(df_netcomplete)\n",
    "        \n",
    "    res[\"NetComplete\"] = df_netcomplete[\"time\"]\n",
    "    res[\"NetComplete Timeouts\"] = df_netcomplete[\"num_timeouts\"]\n",
    "    res[\"NetComplete-std\"] = df_netcomplete[\"time-std\"]\n",
    "    res[system_name] = df_neural[\"time\"]\n",
    "    res[system_name + \"-std\"] = df_neural[\"time-std\"]\n",
    "    res[consistency_col] = df_neural[\"consistency\"]\n",
    "    res[consistency_col+\"-std\"] = df_neural[\"consistency-std\"]\n",
    "    res[full_match_col] = df_neural[\"full_match\"]\n",
    "    del res[\"time\"]\n",
    "    \n",
    "    speedup_factors = res[\"NetComplete\"].values / res[system_name].values\n",
    "    res[\"Speedup\"] = [\"%.1fx\" % f for f in speedup_factors]\n",
    "    \n",
    "    res = res.reset_index()\n",
    "    \n",
    "    return res[[\"bucket\", \"NetComplete\", \"Neural\", \"Speedup\", \"NetComplete Timeouts\", consistency_col, full_match_col, \"NetComplete-std\", \"Neural-std\", consistency_col + \"-std\"]]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "053df4c0",
   "metadata": {},
   "source": [
    "## 2 Requirements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4a7bb5b8",
   "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>bucket</th>\n",
       "      <th>NetComplete</th>\n",
       "      <th>Neural</th>\n",
       "      <th>Speedup</th>\n",
       "      <th>NetComplete Timeouts</th>\n",
       "      <th>Consistency (Neural)</th>\n",
       "      <th>Full Match (Neural)</th>\n",
       "      <th>NetComplete-std</th>\n",
       "      <th>Neural-std</th>\n",
       "      <th>Consistency (Neural)-std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>18.072854</td>\n",
       "      <td>0.640729</td>\n",
       "      <td>28.2x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.968750</td>\n",
       "      <td>0.875</td>\n",
       "      <td>14.545376</td>\n",
       "      <td>0.380590</td>\n",
       "      <td>0.088388</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>60.864079</td>\n",
       "      <td>2.747783</td>\n",
       "      <td>22.2x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.939236</td>\n",
       "      <td>0.750</td>\n",
       "      <td>33.394428</td>\n",
       "      <td>3.288096</td>\n",
       "      <td>0.132790</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>1389.484829</td>\n",
       "      <td>22.300895</td>\n",
       "      <td>62.3x</td>\n",
       "      <td>7</td>\n",
       "      <td>0.988636</td>\n",
       "      <td>0.875</td>\n",
       "      <td>312.584108</td>\n",
       "      <td>26.862637</td>\n",
       "      <td>0.032141</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete     Neural Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small    18.072854   0.640729   28.2x                     0   \n",
       "1  1 Medium    60.864079   2.747783   22.2x                     0   \n",
       "2   2 Large  1389.484829  22.300895   62.3x                     7   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  NetComplete-std  Neural-std  \\\n",
       "0              0.968750                0.875        14.545376    0.380590   \n",
       "1              0.939236                0.750        33.394428    3.288096   \n",
       "2              0.988636                0.875       312.584108   26.862637   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                  0.088388  \n",
       "1                  0.132790  \n",
       "2                  0.032141  "
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "req2 = merge(\n",
    "    read_results_file(nc_files[2]),\n",
    "    read_results_file(neural_files[2], with_consistency=True),\n",
    ")\n",
    "req2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "460d886b",
   "metadata": {},
   "source": [
    "## 8 Requirements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6c7b6ee1",
   "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>bucket</th>\n",
       "      <th>NetComplete</th>\n",
       "      <th>Neural</th>\n",
       "      <th>Speedup</th>\n",
       "      <th>NetComplete Timeouts</th>\n",
       "      <th>Consistency (Neural)</th>\n",
       "      <th>Full Match (Neural)</th>\n",
       "      <th>NetComplete-std</th>\n",
       "      <th>Neural-std</th>\n",
       "      <th>Consistency (Neural)-std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>247.690651</td>\n",
       "      <td>1.065172</td>\n",
       "      <td>232.5x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.960000</td>\n",
       "      <td>0.75</td>\n",
       "      <td>436.900863</td>\n",
       "      <td>0.837845</td>\n",
       "      <td>0.077090</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>1500.000000</td>\n",
       "      <td>3.470269</td>\n",
       "      <td>432.2x</td>\n",
       "      <td>8</td>\n",
       "      <td>0.967839</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3.336769</td>\n",
       "      <td>0.035469</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>1500.000000</td>\n",
       "      <td>30.961408</td>\n",
       "      <td>48.4x</td>\n",
       "      <td>8</td>\n",
       "      <td>0.969444</td>\n",
       "      <td>0.75</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>28.179626</td>\n",
       "      <td>0.056889</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete     Neural Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small   247.690651   1.065172  232.5x                     0   \n",
       "1  1 Medium  1500.000000   3.470269  432.2x                     8   \n",
       "2   2 Large  1500.000000  30.961408   48.4x                     8   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  NetComplete-std  Neural-std  \\\n",
       "0              0.960000                 0.75       436.900863    0.837845   \n",
       "1              0.967839                 0.50         0.000000    3.336769   \n",
       "2              0.969444                 0.75         0.000000   28.179626   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                  0.077090  \n",
       "1                  0.035469  \n",
       "2                  0.056889  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "req8 = merge(\n",
    "    read_results_file(nc_files[8]),\n",
    "    read_results_file(neural_files[8], with_consistency=True),\n",
    ")\n",
    "req8"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5c70c33",
   "metadata": {},
   "source": [
    "## 16 Requirements"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "33b30719",
   "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>bucket</th>\n",
       "      <th>NetComplete</th>\n",
       "      <th>Neural</th>\n",
       "      <th>Speedup</th>\n",
       "      <th>NetComplete Timeouts</th>\n",
       "      <th>Consistency (Neural)</th>\n",
       "      <th>Full Match (Neural)</th>\n",
       "      <th>NetComplete-std</th>\n",
       "      <th>Neural-std</th>\n",
       "      <th>Consistency (Neural)-std</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>1416.828196</td>\n",
       "      <td>2.527836</td>\n",
       "      <td>560.5x</td>\n",
       "      <td>7</td>\n",
       "      <td>0.925770</td>\n",
       "      <td>0.25</td>\n",
       "      <td>235.245388</td>\n",
       "      <td>1.850095</td>\n",
       "      <td>0.069861</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>1500.000000</td>\n",
       "      <td>5.481253</td>\n",
       "      <td>273.7x</td>\n",
       "      <td>8</td>\n",
       "      <td>0.947115</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>3.903356</td>\n",
       "      <td>0.047182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>1500.000000</td>\n",
       "      <td>69.092142</td>\n",
       "      <td>21.7x</td>\n",
       "      <td>8</td>\n",
       "      <td>0.958699</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>108.170768</td>\n",
       "      <td>0.033228</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete     Neural Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small  1416.828196   2.527836  560.5x                     7   \n",
       "1  1 Medium  1500.000000   5.481253  273.7x                     8   \n",
       "2   2 Large  1500.000000  69.092142   21.7x                     8   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  NetComplete-std  Neural-std  \\\n",
       "0              0.925770                 0.25       235.245388    1.850095   \n",
       "1              0.947115                 0.25         0.000000    3.903356   \n",
       "2              0.958699                 0.25         0.000000  108.170768   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                  0.069861  \n",
       "1                  0.047182  \n",
       "2                  0.033228  "
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "req16 = merge(\n",
    "    read_results_file(nc_files[16]),\n",
    "    read_results_file(neural_files[16], with_consistency=True),\n",
    ")\n",
    "req16"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "68b33c6c",
   "metadata": {},
   "source": [
    "## Format as LaTex table"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0865343f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\midrule\n",
      "2 reqs. & S & 18.07$s\\pm$14.55 & 0.64s$\\pm$0.38 & \\textbf{28.2x} & 0.97$\\pm$0.09 & 7/8\\\\\n",
      " & M & 60.86$s\\pm$33.39 & 2.75s$\\pm$3.29 & \\textbf{22.2x} & 0.94$\\pm$0.13 & 6/8\\\\\n",
      " & L & 1389.48$s\\pm$312.58\\tiny{  7/8 TO} & 22.30s$\\pm$26.86 & \\textbf{62.3x} & 0.99$\\pm$0.03 & 7/8\\\\\n",
      "\\midrule\n",
      "8 reqs. & S & 247.69$s\\pm$436.90 & 1.07s$\\pm$0.84 & \\textbf{232.5x} & 0.96$\\pm$0.08 & 6/8\\\\\n",
      " & M & >25m\\tiny{  8/8 TO} & 3.47s$\\pm$3.34 & \\textbf{432.2x} & 0.97$\\pm$0.04 & 4/8\\\\\n",
      " & L & >25m\\tiny{  8/8 TO} & 30.96s$\\pm$28.18 & \\textbf{48.4x} & 0.97$\\pm$0.06 & 6/8\\\\\n",
      "\\midrule\n",
      "16 reqs. & S & 1416.83$s\\pm$235.25\\tiny{  7/8 TO} & 2.53s$\\pm$1.85 & \\textbf{560.5x} & 0.93$\\pm$0.07 & 2/8\\\\\n",
      " & M & >25m\\tiny{  8/8 TO} & 5.48s$\\pm$3.90 & \\textbf{273.7x} & 0.95$\\pm$0.05 & 2/8\\\\\n",
      " & L & >25m\\tiny{  8/8 TO} & 69.09s$\\pm$108.17 & \\textbf{21.7x} & 0.96$\\pm$0.03 & 2/8\\\\\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "reqs_counts = [2, 8, 16]\n",
    "\n",
    "for nreqs, reqs in zip(reqs_counts, [req2, req8, req16]):\n",
    "    print(\"\\\\midrule\")\n",
    "    for i, row in enumerate(reqs.iloc):\n",
    "        row = list(row.values)\n",
    "        \n",
    "        def str_v(v, i):\n",
    "            if v == \"0 Small\": return \"S\"\n",
    "            if v == \"1 Medium\": return \"M\"\n",
    "            if v == \"2 Large\": return \"L\"\n",
    "\n",
    "            if type(v) is np.float64:\n",
    "                highlighted_indices = set([2])\n",
    "                res = \"\"\n",
    "                if i in highlighted_indices: res += \"\\\\textbf{\"\n",
    "                res += (\"%.3f\" % v).rstrip(\"0\").rstrip(\".\")\n",
    "                if i == 1 or i == 2: res += \"s\"\n",
    "                if i in highlighted_indices: res += \"}\"\n",
    "                \n",
    "                return res\n",
    "            else: return str(v)\n",
    "\n",
    "\n",
    "        row_data = dict([(reqs.columns[j],v) for j,v in enumerate(row)])\n",
    "        num_timeouts = row_data[\"NetComplete Timeouts\"]\n",
    "\n",
    "        row_str = \"\"\n",
    "        row_str += str_v(row_data[\"bucket\"], 0)\n",
    "        \n",
    "        nc_time = (\"%.2f\" % row_data[\"NetComplete\"])\n",
    "        if row_data[\"NetComplete\"] == 1500: \n",
    "            nc_time = \">25m\"\n",
    "        row_str += \" & \" + nc_time\n",
    "        if row_data[\"NetComplete\"] < 1500: \n",
    "            row_str += \"$s\\pm$\" + \"%.2f\" % row_data[\"NetComplete-std\"]\n",
    "        if num_timeouts > 0:\n",
    "            row_str += \"\\\\tiny{\" + \"  {}/8 TO\".format(num_timeouts) + \"}\"\n",
    "\n",
    "        neural_time = (\"%.2f\" % row_data[system_name])\n",
    "        neural_std = (\"%.2f\" % row_data[system_name+\"-std\"])\n",
    "        row_str += \" & \" + neural_time + \"s$\\pm$\" + neural_std\n",
    "\n",
    "        row_str += \" & \\\\textbf{\" + row_data[\"Speedup\"] + \"}\"\n",
    "        row_str += \" & \" + \"%.2f\" % row_data[\"Consistency (Neural)\"]\n",
    "        row_str += \"$\\pm$\" + \"%.2f\" % row_data[\"Consistency (Neural)-std\"]\n",
    "        row_str += \" & \" + \"%d/8\" % int(8 * row_data[\"Full Match (Neural)\"])\n",
    "            \n",
    "        if i == 0: \n",
    "            row_str = \"{} reqs. & \".format(nreqs) + row_str\n",
    "        else:\n",
    "            row_str = \" & \" + row_str\n",
    "        print(row_str + \"\\\\\\\\\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bbd79feb",
   "metadata": {},
   "source": [
    "## GPU"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4d7a3410",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\midrule\n",
      "2 reqs. & S & 18.07$s\\pm$14.55 & 0.50s$\\pm$0.41 & \\textbf{36.4x} & 0.97$\\pm$0.09 & 7/8\\\\\n",
      " & M & 60.86$s\\pm$33.39 & 0.68s$\\pm$0.53 & \\textbf{90.1x} & 0.94$\\pm$0.13 & 6/8\\\\\n",
      "\\midrule\n",
      "8 reqs. & S & 247.69$s\\pm$436.90 & 0.72s$\\pm$0.48 & \\textbf{344.7x} & 0.96$\\pm$0.08 & 6/8\\\\\n",
      " & M & >25m\\tiny{  8/8 TO} & 1.05s$\\pm$0.57 & \\textbf{1424.3x} & 0.97$\\pm$0.04 & 4/8\\\\\n",
      "\\midrule\n",
      "16 reqs. & S & 1416.83$s\\pm$235.25\\tiny{  7/8 TO} & 1.30s$\\pm$0.40 & \\textbf{1093.0x} & 0.92$\\pm$0.06 & 1/8\\\\\n",
      " & M & >25m\\tiny{  8/8 TO} & 1.38s$\\pm$0.40 & \\textbf{1086.6x} & 0.94$\\pm$0.05 & 1/8\\\\\n"
     ]
    }
   ],
   "source": [
    "neural_gpu_files = get_neural_files(\"./results/bgp-gpu/\")\n",
    "\n",
    "req2_gpu = merge(\n",
    "    read_results_file(nc_files[2]),\n",
    "    read_results_file(neural_gpu_files[2], with_consistency=True),\n",
    ")\n",
    "req8_gpu = merge(\n",
    "    read_results_file(nc_files[8]),\n",
    "    read_results_file(neural_gpu_files[8], with_consistency=True),\n",
    ")\n",
    "req16_gpu = merge(\n",
    "    read_results_file(nc_files[16]),\n",
    "    read_results_file(neural_gpu_files[16], with_consistency=True),\n",
    ")\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "reqs_counts = [2, 8, 16]\n",
    "\n",
    "for nreqs, reqs in zip(reqs_counts, [req2_gpu, req8_gpu, req16_gpu]):\n",
    "    print(\"\\\\midrule\")\n",
    "    for i, row in enumerate(reqs.iloc):\n",
    "        row = list(row.values)\n",
    "        \n",
    "        def str_v(v, i):\n",
    "            if v == \"0 Small\": return \"S\"\n",
    "            if v == \"1 Medium\": return \"M\"\n",
    "            if v == \"2 Large\": return \"L\"\n",
    "\n",
    "            if type(v) is np.float64:\n",
    "                highlighted_indices = set([2])\n",
    "                res = \"\"\n",
    "                if i in highlighted_indices: res += \"\\\\textbf{\"\n",
    "                res += (\"%.3f\" % v).rstrip(\"0\").rstrip(\".\")\n",
    "                if i == 1 or i == 2: res += \"s\"\n",
    "                if i in highlighted_indices: res += \"}\"\n",
    "                \n",
    "                return res\n",
    "            else: return str(v)\n",
    "\n",
    "        row_data = dict([(reqs.columns[j],v) for j,v in enumerate(row)])\n",
    "        num_timeouts = row_data[\"NetComplete Timeouts\"]\n",
    "\n",
    "        row_str = \"\"\n",
    "        row_str += str_v(row_data[\"bucket\"], 0)\n",
    "\n",
    "        if str_v(row_data[\"bucket\"], 0) == \"L\":\n",
    "            continue\n",
    "        \n",
    "        nc_time = (\"%.2f\" % row_data[\"NetComplete\"])\n",
    "        if row_data[\"NetComplete\"] == 1500: \n",
    "            nc_time = \">25m\"\n",
    "        row_str += \" & \" + nc_time\n",
    "        if row_data[\"NetComplete\"] < 1500: \n",
    "            row_str += \"$s\\pm$\" + \"%.2f\" % row_data[\"NetComplete-std\"]\n",
    "        if num_timeouts > 0:\n",
    "            row_str += \"\\\\tiny{\" + \"  {}/8 TO\".format(num_timeouts) + \"}\"\n",
    "\n",
    "        neural_time = (\"%.2f\" % row_data[system_name])\n",
    "        neural_std = (\"%.2f\" % row_data[system_name+\"-std\"])\n",
    "        row_str += \" & \" + neural_time + \"s$\\pm$\" + neural_std\n",
    "\n",
    "        row_str += \" & \\\\textbf{\" + row_data[\"Speedup\"] + \"}\"\n",
    "        row_str += \" & \" + \"%.2f\" % row_data[\"Consistency (Neural)\"]\n",
    "        row_str += \"$\\pm$\" + \"%.2f\" % row_data[\"Consistency (Neural)-std\"]\n",
    "        row_str += \" & \" + \"%d/8\" % int(8 * row_data[\"Full Match (Neural)\"])\n",
    "            \n",
    "        if i == 0: \n",
    "            row_str = \"{} reqs. & \".format(nreqs) + row_str\n",
    "        else:\n",
    "            row_str = \" & \" + row_str\n",
    "        print(row_str + \"\\\\\\\\\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "880db2be",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "9c2aca3d0dfc99fb2efc8287a7808a7621f9ab3042aa12ae3d168b7497f5397d"
  },
  "kernelspec": {
   "display_name": "Python 3.9.7 ('nsynth-sub')",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
