{
 "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  time-std\n",
      "bucket                                                                   \n",
      "0 Small   0.265297             0        8          0          7  0.089825\n",
      "1 Medium  0.403998             0        8          8         15  0.089433\n",
      "2 Large   0.943937             0        8         16         23  0.334002\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",
    "    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>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",
       "      <td>0.089825</td>\n",
       "      <td>0.002574</td>\n",
       "      <td>0.0</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",
       "      <td>0.089433</td>\n",
       "      <td>0.001602</td>\n",
       "      <td>0.0</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",
       "      <td>0.334002</td>\n",
       "      <td>0.078821</td>\n",
       "      <td>0.0</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)  NetComplete-std  Neural-std  \\\n",
       "0                   1.0                 True         0.089825    0.002574   \n",
       "1                   1.0                 True         0.089433    0.001602   \n",
       "2                   1.0                 True         0.334002    0.078821   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                       0.0  \n",
       "1                       0.0  \n",
       "2                       0.0  "
      ]
     },
     "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": 16,
   "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>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",
       "      <td>0.176679</td>\n",
       "      <td>0.122562</td>\n",
       "      <td>0.035177</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",
       "      <td>0.401317</td>\n",
       "      <td>0.009120</td>\n",
       "      <td>0.000000</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",
       "      <td>1.112488</td>\n",
       "      <td>0.150805</td>\n",
       "      <td>0.025535</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)  NetComplete-std  Neural-std  \\\n",
       "0              0.982413                 0.75         0.176679    0.122562   \n",
       "1              1.000000                 1.00         0.401317    0.009120   \n",
       "2              0.980968                 0.50         1.112488    0.150805   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                  0.035177  \n",
       "1                  0.000000  \n",
       "2                  0.025535  "
      ]
     },
     "execution_count": 16,
     "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": 17,
   "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>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",
       "      <td>0.372218</td>\n",
       "      <td>0.142982</td>\n",
       "      <td>0.012466</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",
       "      <td>0.696411</td>\n",
       "      <td>0.158519</td>\n",
       "      <td>0.012160</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",
       "      <td>772.900410</td>\n",
       "      <td>0.110450</td>\n",
       "      <td>0.037000</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)  NetComplete-std  Neural-std  \\\n",
       "0              0.991073                0.625         0.372218    0.142982   \n",
       "1              0.989153                0.500         0.696411    0.158519   \n",
       "2              0.986919                0.875       772.900410    0.110450   \n",
       "\n",
       "   Consistency (Neural)-std  \n",
       "0                  0.012466  \n",
       "1                  0.012160  \n",
       "2                  0.037000  "
      ]
     },
     "execution_count": 17,
     "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": 20,
   "id": "0865343f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\midrule\n",
      "2 reqs. & S & 0.27$s\\pm$0.09 & 0.09s$\\pm$0.00 & \\textbf{2.9x} & 1.00$\\pm$0.00 & 8/8\\\\\n",
      " & M & 0.40$s\\pm$0.09 & 0.10s$\\pm$0.00 & \\textbf{4.1x} & 1.00$\\pm$0.00 & 8/8\\\\\n",
      " & L & 0.94$s\\pm$0.33 & 0.14s$\\pm$0.08 & \\textbf{6.7x} & 1.00$\\pm$0.00 & 8/8\\\\\n",
      "\\midrule\n",
      "8 reqs. & S & 0.88$s\\pm$0.18 & 0.16s$\\pm$0.12 & \\textbf{5.3x} & 0.98$\\pm$0.04 & 6/8\\\\\n",
      " & M & 1.52$s\\pm$0.40 & 0.10s$\\pm$0.01 & \\textbf{14.7x} & 1.00$\\pm$0.00 & 8/8\\\\\n",
      " & L & 3.50$s\\pm$1.11 & 0.32s$\\pm$0.15 & \\textbf{11.1x} & 0.98$\\pm$0.03 & 4/8\\\\\n",
      "\\midrule\n",
      "16 reqs. & S & 1.65$s\\pm$0.37 & 0.21s$\\pm$0.14 & \\textbf{7.9x} & 0.99$\\pm$0.01 & 5/8\\\\\n",
      " & M & 2.65$s\\pm$0.70 & 0.25s$\\pm$0.16 & \\textbf{10.8x} & 0.99$\\pm$0.01 & 4/8\\\\\n",
      " & L & 566.64$s\\pm$772.90\\tiny{  3/8 TO} & 0.23s$\\pm$0.11 & \\textbf{2430.4x} & 0.99$\\pm$0.04 & 7/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": "code",
   "execution_count": null,
   "id": "052f6922",
   "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
}
