{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "dcda9008",
   "metadata": {},
   "source": [
    "## Table Aggregation: OSPF Synthesis Time\n",
    "\n",
    "In this notebook we aggregate the raw data into tables on ospf synthesis time as used in our figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "56565e6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "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(\"ospf-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(\"ospf-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\n",
      "bucket                                                           \n",
      "0 Small     1.650322             0        8          0          7\n",
      "1 Medium    2.645937             0        8          8         15\n",
      "2 Large   566.635635             3        8         16         23\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(\"ospf-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",
    "    del res[\"num_nodes\"]\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",
    "    \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[16]))"
   ]
  },
  {
   "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[system_name] = df_neural[\"time\"]\n",
    "    res[consistency_col] = df_neural[\"consistency\"]\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]]"
   ]
  },
  {
   "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>0.265297</td>\n",
       "      <td>0.091140</td>\n",
       "      <td>2.9x</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>0.403998</td>\n",
       "      <td>0.097940</td>\n",
       "      <td>4.1x</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>0.943937</td>\n",
       "      <td>0.140039</td>\n",
       "      <td>6.7x</td>\n",
       "      <td>0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete    Neural Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small     0.265297  0.091140    2.9x                     0   \n",
       "1  1 Medium     0.403998  0.097940    4.1x                     0   \n",
       "2   2 Large     0.943937  0.140039    6.7x                     0   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  \n",
       "0                   1.0                 True  \n",
       "1                   1.0                 True  \n",
       "2                   1.0                 True  "
      ]
     },
     "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>0.876088</td>\n",
       "      <td>0.164134</td>\n",
       "      <td>5.3x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.982413</td>\n",
       "      <td>0.75</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>1.517269</td>\n",
       "      <td>0.103424</td>\n",
       "      <td>14.7x</td>\n",
       "      <td>0</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>3.504761</td>\n",
       "      <td>0.316284</td>\n",
       "      <td>11.1x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.980968</td>\n",
       "      <td>0.50</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete    Neural Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small     0.876088  0.164134    5.3x                     0   \n",
       "1  1 Medium     1.517269  0.103424   14.7x                     0   \n",
       "2   2 Large     3.504761  0.316284   11.1x                     0   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  \n",
       "0              0.982413                 0.75  \n",
       "1              1.000000                 1.00  \n",
       "2              0.980968                 0.50  "
      ]
     },
     "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",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0 Small</td>\n",
       "      <td>1.650322</td>\n",
       "      <td>0.209984</td>\n",
       "      <td>7.9x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.991073</td>\n",
       "      <td>0.625</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1 Medium</td>\n",
       "      <td>2.645937</td>\n",
       "      <td>0.245172</td>\n",
       "      <td>10.8x</td>\n",
       "      <td>0</td>\n",
       "      <td>0.989153</td>\n",
       "      <td>0.500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 Large</td>\n",
       "      <td>566.635635</td>\n",
       "      <td>0.233142</td>\n",
       "      <td>2430.4x</td>\n",
       "      <td>3</td>\n",
       "      <td>0.986919</td>\n",
       "      <td>0.875</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     bucket  NetComplete    Neural  Speedup  NetComplete Timeouts  \\\n",
       "0   0 Small     1.650322  0.209984     7.9x                     0   \n",
       "1  1 Medium     2.645937  0.245172    10.8x                     0   \n",
       "2   2 Large   566.635635  0.233142  2430.4x                     3   \n",
       "\n",
       "   Consistency (Neural)  Full Match (Neural)  \n",
       "0              0.991073                0.625  \n",
       "1              0.989153                0.500  \n",
       "2              0.986919                0.875  "
      ]
     },
     "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": "code",
   "execution_count": 8,
   "id": "0865343f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\midrule\n",
      "2 requirements &Small & 0.265s & \\textbf{0.091s} & 2.9x & 1 & True\\\\\n",
      " &Medium & 0.404s & \\textbf{0.098s} & 4.1x & 1 & True\\\\\n",
      " &Large & 0.944s & \\textbf{0.14s} & 6.7x & 1 & True\\\\\n",
      "\\midrule\n",
      "8 requirements &Small & 0.876s & \\textbf{0.164s} & 5.3x & 0.982 & 0.75\\\\\n",
      " &Medium & 1.517s & \\textbf{0.103s} & 14.7x & 1 & 1\\\\\n",
      " &Large & 3.505s & \\textbf{0.316s} & 11.1x & 0.981 & 0.5\\\\\n",
      "\\midrule\n",
      "16 requirements &Small & 1.65s & \\textbf{0.21s} & 7.9x & 0.991 & 0.625\\\\\n",
      " &Medium & 2.646s & \\textbf{0.245s} & 10.8x & 0.989 & 0.5\\\\\n",
      " &Large & 566.636s\\tiny{  3/8 TO} & \\textbf{0.233s} & 2430.4x & 0.987 & 0.875\\\\\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",
    "        num_timeouts = row[4]\n",
    "        del row[4]\n",
    "        def str_v(v, i):\n",
    "            if v == \"0 Small\": return \"Small\"\n",
    "            if v == \"1 Medium\": return \"Medium\"\n",
    "            if v == \"2 Large\": return \"Large\"\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",
    "                if i == 1: # NetComplete Time\n",
    "                    if num_timeouts > 0:\n",
    "                        res += \"\\\\tiny{\" + \"  {}/8 TO\".format(num_timeouts) + \"}\"\n",
    "                return res\n",
    "            else: return str(v)\n",
    "        row_values = [str_v(v, i) for i,v in enumerate(row)]\n",
    "            \n",
    "        prefix = \" &\"\n",
    "        if i == 0: prefix = \"{} requirements &\".format(nreqs)\n",
    "        print(prefix + \" & \".join(row_values) + \"\\\\\\\\\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
