{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "3ffe1321",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import random\n",
    "import os\n",
    "from config import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.patches as mpatches\n",
    "import seaborn as sns\n",
    "from matplotlib import font_manager as fm\n",
    "from matplotlib.ticker import FixedLocator\n",
    "from sklearn.metrics import confusion_matrix, ConfusionMatrixDisplay"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "c1ac718a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_schedule(unique_ids, qps, random_seed, shuffle=False):\n",
    "    ids = list(unique_ids)\n",
    "    rng = np.random.default_rng(random_seed)\n",
    "    if shuffle: rng.shuffle(ids)\n",
    "    n = len(ids)\n",
    "    if n == 0:\n",
    "        return pd.DataFrame(columns=[\"request_id\",\"model_id\",\"arrival_time_s\",\"qps\"])\n",
    "    arrivals = np.cumsum(rng.exponential(1.0/qps, n))\n",
    "    return pd.DataFrame({\n",
    "        \"unique_id\": ids,\n",
    "        \"model_id\": model_id,\n",
    "        \"arrival_time_s\": arrivals\n",
    "    })\n",
    "\n",
    "\n",
    "def postprocess(df_raw):\n",
    "    df_processed = df_raw.rename(columns={'uid': 'unique_id'})\n",
    "    if 'latency_default' in df_processed.columns:\n",
    "        df_processed = df_processed.rename(columns={'latency_default': 'processing_time_s'})\n",
    "    elif 'latency_shortm' in df_processed.columns:\n",
    "        df_processed = df_processed.rename(columns={'latency_shortm': 'processing_time_s'})\n",
    "    elif 'latency_decode' in df_processed.columns and 'latency_probe' in df_processed.columns and 'latency_prediction' in df_processed.columns:\n",
    "        df_processed = df_processed.rename(\n",
    "            columns={'latency_decode': 'decode_time_s',\n",
    "                     'latency_probe': 'probe_time_s',\n",
    "                     'latency_prediction': 'prediction_time_s'})\n",
    "        df_processed['processing_time_s'] = df_processed['decode_time_s'] + df_processed['probe_time_s'] + df_processed['prediction_time_s']\n",
    "    if 'latency_prefill' in df_processed.columns:\n",
    "        df_processed = df_processed.rename(columns={'latency_prefill': 'prefill_time_s'})\n",
    "    return df_processed\n",
    "\n",
    "\n",
    "def compute_latency(schedule_wtime):\n",
    "    arrival, processing = schedule_wtime.arrival_time_s.values, schedule_wtime.processing_time_s.values\n",
    "    start_time, finish_time = list(), list()\n",
    "    for i in range(len(arrival)):\n",
    "        if i == 0:\n",
    "            start_time.append(arrival[i])\n",
    "            finish_time.append(arrival[i] + processing[i])\n",
    "        else:\n",
    "            start_time.append(max(arrival[i], finish_time[i-1]))\n",
    "            finish_time.append(start_time[i] + processing[i])\n",
    "    start_time, finish_time = np.array(start_time), np.array(finish_time)\n",
    "    ret = schedule_wtime[['unique_id', 'processing_time_s']].copy()\n",
    "    for other_col in [\n",
    "        'probe_time_s',\n",
    "        'prediction_time_s',\n",
    "        'decode_time_s',\n",
    "        'prefill_time_s',\n",
    "    ]:\n",
    "        if other_col in schedule_wtime.columns:\n",
    "            ret[other_col] = schedule_wtime[other_col].values\n",
    "    ret['start_time_s'] = start_time\n",
    "    ret['finish_time_s'] = finish_time\n",
    "    ret['queueing_time_s'] = start_time - arrival\n",
    "    ret['latency_s'] = finish_time - arrival\n",
    "    if 'prefill_time_s' in ret.columns:\n",
    "        ret['ttft_s'] = ret['prefill_time_s'] + ret['queueing_time_s']\n",
    "    return ret"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "bea89609",
   "metadata": {},
   "outputs": [],
   "source": [
    "os.makedirs(\"schedule\", exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "id": "64879140",
   "metadata": {},
   "outputs": [],
   "source": [
    "cols = list()\n",
    "for dataset in ['gsm8k', 'mmlu', 'math']:\n",
    "    for metric in ['mean', 'P50', 'P95']:\n",
    "        cols.append(f\"{dataset}_{metric}\")\n",
    "\n",
    "results = pd.DataFrame(\n",
    "    index=['default', 'shortm', 'duchess'],\n",
    "    columns=cols\n",
    ")\n",
    "\n",
    "results_ttft = pd.DataFrame(\n",
    "    index=['default', 'shortm', 'duchess'],\n",
    "    columns=cols\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8560739d",
   "metadata": {},
   "source": [
    "# GSM8K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "21e797c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"gsm8k\"\n",
    "model_id = \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\n",
    "qpm =2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "id": "421e2409",
   "metadata": {},
   "outputs": [],
   "source": [
    "prefill_results = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_prefill.csv\"))\n",
    "\n",
    "default = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_default.csv\"))\n",
    "default = default.merge(prefill_results, on='uid', how='inner')\n",
    "default = postprocess(default)\n",
    "\n",
    "duchess = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_duchess_vllm.csv\"))\n",
    "duchess2 = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_torch.csv\"))\n",
    "duchess = duchess.merge(duchess2, on=\"uid\", how=\"inner\").merge(prefill_results, on='uid', how='inner')\n",
    "duchess = postprocess(duchess)\n",
    "\n",
    "shortm = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_shortm.csv\"))\n",
    "shortm = shortm.merge(prefill_results, on='uid', how='inner')\n",
    "shortm = postprocess(shortm)\n",
    "\n",
    "schedule = generate_schedule(default.unique_id.values.tolist(), qpm/60, 0, True)\n",
    "\n",
    "default_results = schedule.merge(default, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "default_results = compute_latency(default_results)\n",
    "duchess_results = schedule.merge(duchess, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "duchess_results = compute_latency(duchess_results)\n",
    "shortm_results = schedule.merge(shortm, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "shortm_results = compute_latency(shortm_results)\n",
    "\n",
    "results.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"latency_s\"].mean()\n",
    "results.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"latency_s\"].median()\n",
    "results.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"latency_s\"].mean()\n",
    "results.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"latency_s\"].median()\n",
    "results.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"latency_s\"].mean()\n",
    "results.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"latency_s\"].median()\n",
    "results.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"latency_s\"].quantile(0.95)\n",
    "\n",
    "results_ttft.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"ttft_s\"].quantile(0.95)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "11d0e7a1",
   "metadata": {},
   "source": [
    "# MMLU"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "id": "d34301b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"mmlu\"\n",
    "model_id = \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\n",
    "qpm = 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "id": "fb410936",
   "metadata": {},
   "outputs": [],
   "source": [
    "prefill_results = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_prefill.csv\"))\n",
    "\n",
    "default = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_default.csv\"))\n",
    "default = default.merge(prefill_results, on='uid', how='inner')\n",
    "default = postprocess(default)\n",
    "\n",
    "duchess = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_duchess_vllm.csv\"))\n",
    "duchess2 = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_torch.csv\"))\n",
    "duchess = duchess.merge(duchess2, on=\"uid\", how=\"inner\").merge(prefill_results, on='uid', how='inner')\n",
    "duchess = postprocess(duchess)\n",
    "\n",
    "shortm = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_shortm.csv\"))\n",
    "shortm = shortm.merge(prefill_results, on='uid', how='inner')\n",
    "shortm = postprocess(shortm)\n",
    "\n",
    "schedule = generate_schedule(default.unique_id.values.tolist(), qpm/60, 0, True)\n",
    "\n",
    "default_results = schedule.merge(default, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "default_results = compute_latency(default_results)\n",
    "duchess_results = schedule.merge(duchess, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "duchess_results = compute_latency(duchess_results)\n",
    "shortm_results = schedule.merge(shortm, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "shortm_results = compute_latency(shortm_results)\n",
    "\n",
    "results.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"latency_s\"].mean()\n",
    "results.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"latency_s\"].median()\n",
    "results.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"latency_s\"].mean()\n",
    "results.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"latency_s\"].median()\n",
    "results.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"latency_s\"].mean()\n",
    "results.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"latency_s\"].median()\n",
    "results.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"latency_s\"].quantile(0.95)\n",
    "\n",
    "results_ttft.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"ttft_s\"].quantile(0.95)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bd9d81f5",
   "metadata": {},
   "source": [
    "# MATH"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "8e856dda",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"math\"\n",
    "model_id = \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\n",
    "\n",
    "qpm = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 135,
   "id": "16f01cc6",
   "metadata": {},
   "outputs": [],
   "source": [
    "prefill_results = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_prefill.csv\"))\n",
    "\n",
    "default = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_default.csv\"))\n",
    "default = default.merge(prefill_results, on='uid', how='inner')\n",
    "default = postprocess(default)\n",
    "\n",
    "duchess = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_duchess_vllm.csv\"))\n",
    "duchess2 = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_torch.csv\"))\n",
    "duchess = duchess.merge(duchess2, on=\"uid\", how=\"inner\").merge(prefill_results, on='uid', how='inner')\n",
    "duchess = postprocess(duchess)\n",
    "\n",
    "shortm = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_shortm.csv\"))\n",
    "shortm = shortm.merge(prefill_results, on='uid', how='inner')\n",
    "shortm = postprocess(shortm)\n",
    "\n",
    "schedule = generate_schedule(default.unique_id.values.tolist(), qpm/60, 0, True)\n",
    "\n",
    "default_results = schedule.merge(default, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "default_results = compute_latency(default_results)\n",
    "duchess_results = schedule.merge(duchess, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "duchess_results = compute_latency(duchess_results)\n",
    "shortm_results = schedule.merge(shortm, on=\"unique_id\", how=\"inner\").sort_values(by=\"arrival_time_s\", ascending=True)\n",
    "shortm_results = compute_latency(shortm_results)\n",
    "\n",
    "results.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"latency_s\"].mean()\n",
    "results.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"latency_s\"].median()\n",
    "results.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"latency_s\"].mean()\n",
    "results.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"latency_s\"].median()\n",
    "results.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"latency_s\"].quantile(0.95)\n",
    "results.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"latency_s\"].mean()\n",
    "results.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"latency_s\"].median()\n",
    "results.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"latency_s\"].quantile(0.95)\n",
    "\n",
    "results_ttft.loc[\"default\", \"{}_mean\".format(dataset)] = default_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"default\", \"{}_P50\".format(dataset)] = default_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"default\", \"{}_P95\".format(dataset)] = default_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"shortm\", \"{}_mean\".format(dataset)] = shortm_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"shortm\", \"{}_P50\".format(dataset)] = shortm_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"shortm\", \"{}_P95\".format(dataset)] = shortm_results[\"ttft_s\"].quantile(0.95)\n",
    "results_ttft.loc[\"duchess\", \"{}_mean\".format(dataset)] = duchess_results[\"ttft_s\"].mean()\n",
    "results_ttft.loc[\"duchess\", \"{}_P50\".format(dataset)] = duchess_results[\"ttft_s\"].median()\n",
    "results_ttft.loc[\"duchess\", \"{}_P95\".format(dataset)] = duchess_results[\"ttft_s\"].quantile(0.95)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 136,
   "id": "b01be6c8",
   "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>gsm8k_mean</th>\n",
       "      <th>gsm8k_P50</th>\n",
       "      <th>gsm8k_P95</th>\n",
       "      <th>mmlu_mean</th>\n",
       "      <th>mmlu_P50</th>\n",
       "      <th>mmlu_P95</th>\n",
       "      <th>math_mean</th>\n",
       "      <th>math_P50</th>\n",
       "      <th>math_P95</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>default</th>\n",
       "      <td>54.05012</td>\n",
       "      <td>40.821606</td>\n",
       "      <td>156.091194</td>\n",
       "      <td>82.763141</td>\n",
       "      <td>62.718002</td>\n",
       "      <td>215.341244</td>\n",
       "      <td>137.657454</td>\n",
       "      <td>117.271895</td>\n",
       "      <td>319.485661</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>shortm</th>\n",
       "      <td>15.65983</td>\n",
       "      <td>10.008325</td>\n",
       "      <td>44.284843</td>\n",
       "      <td>23.892612</td>\n",
       "      <td>14.668851</td>\n",
       "      <td>72.16322</td>\n",
       "      <td>69.8558</td>\n",
       "      <td>59.967037</td>\n",
       "      <td>182.902963</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>duchess</th>\n",
       "      <td>10.479341</td>\n",
       "      <td>7.677601</td>\n",
       "      <td>24.685329</td>\n",
       "      <td>16.973231</td>\n",
       "      <td>9.214003</td>\n",
       "      <td>66.725873</td>\n",
       "      <td>58.802565</td>\n",
       "      <td>48.75564</td>\n",
       "      <td>154.393225</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        gsm8k_mean  gsm8k_P50   gsm8k_P95  mmlu_mean   mmlu_P50    mmlu_P95  \\\n",
       "default   54.05012  40.821606  156.091194  82.763141  62.718002  215.341244   \n",
       "shortm    15.65983  10.008325   44.284843  23.892612  14.668851    72.16322   \n",
       "duchess  10.479341   7.677601   24.685329  16.973231   9.214003   66.725873   \n",
       "\n",
       "          math_mean    math_P50    math_P95  \n",
       "default  137.657454  117.271895  319.485661  \n",
       "shortm      69.8558   59.967037  182.902963  \n",
       "duchess   58.802565    48.75564  154.393225  "
      ]
     },
     "execution_count": 136,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results.round(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "e5d50738",
   "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>gsm8k_mean</th>\n",
       "      <th>gsm8k_P50</th>\n",
       "      <th>gsm8k_P95</th>\n",
       "      <th>mmlu_mean</th>\n",
       "      <th>mmlu_P50</th>\n",
       "      <th>mmlu_P95</th>\n",
       "      <th>math_mean</th>\n",
       "      <th>math_P50</th>\n",
       "      <th>math_P95</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>default</th>\n",
       "      <td>34.202594</td>\n",
       "      <td>16.131161</td>\n",
       "      <td>134.530328</td>\n",
       "      <td>59.732453</td>\n",
       "      <td>39.873542</td>\n",
       "      <td>191.030573</td>\n",
       "      <td>88.188908</td>\n",
       "      <td>63.730137</td>\n",
       "      <td>260.310734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>shortm</th>\n",
       "      <td>5.124085</td>\n",
       "      <td>0.069799</td>\n",
       "      <td>27.374893</td>\n",
       "      <td>10.311817</td>\n",
       "      <td>0.071751</td>\n",
       "      <td>52.335671</td>\n",
       "      <td>33.759266</td>\n",
       "      <td>10.805717</td>\n",
       "      <td>142.064019</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>duchess</th>\n",
       "      <td>2.755635</td>\n",
       "      <td>0.067949</td>\n",
       "      <td>14.42746</td>\n",
       "      <td>6.732808</td>\n",
       "      <td>0.067377</td>\n",
       "      <td>43.738885</td>\n",
       "      <td>27.607184</td>\n",
       "      <td>2.214952</td>\n",
       "      <td>118.56194</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "        gsm8k_mean  gsm8k_P50   gsm8k_P95  mmlu_mean   mmlu_P50    mmlu_P95  \\\n",
       "default  34.202594  16.131161  134.530328  59.732453  39.873542  191.030573   \n",
       "shortm    5.124085   0.069799   27.374893  10.311817   0.071751   52.335671   \n",
       "duchess   2.755635   0.067949    14.42746   6.732808   0.067377   43.738885   \n",
       "\n",
       "         math_mean   math_P50    math_P95  \n",
       "default  88.188908  63.730137  260.310734  \n",
       "shortm   33.759266  10.805717  142.064019  \n",
       "duchess  27.607184   2.214952   118.56194  "
      ]
     },
     "execution_count": 137,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "results_ttft.round(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "5e7f475b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "49.530475761167466 35.6184619140625 64.04465820312501\n"
     ]
    }
   ],
   "source": [
    "# Check upper quantiles of default SC processing time\n",
    "# to determine suitable QPMs\n",
    "\n",
    "print(default.processing_time_s.mean(), np.percentile(default.processing_time_s, 25), np.percentile(default.processing_time_s, 75))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "id": "873df895",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gsm8k_mean: latency saving: 80.61%, ttft saving: 91.94%\n",
      "gsm8k_P50: latency saving: 81.19%, ttft saving: 99.58%\n",
      "gsm8k_P95: latency saving: 84.19%, ttft saving: 89.28%\n",
      "mmlu_mean: latency saving: 79.49%, ttft saving: 88.73%\n",
      "mmlu_P50: latency saving: 85.31%, ttft saving: 99.83%\n",
      "mmlu_P95: latency saving: 69.01%, ttft saving: 77.10%\n",
      "math_mean: latency saving: 57.28%, ttft saving: 68.70%\n",
      "math_P50: latency saving: 58.43%, ttft saving: 96.52%\n",
      "math_P95: latency saving: 51.67%, ttft saving: 54.45%\n"
     ]
    }
   ],
   "source": [
    "for dataset in ['gsm8k', 'mmlu', 'math']:\n",
    "    for metric in ['mean', 'P50', 'P95']:\n",
    "        default_lat, default_ttft = results.loc['default', f'{dataset}_{metric}'], results_ttft.loc['default', f'{dataset}_{metric}']\n",
    "        duchess_lat, duchess_ttft = results.loc['duchess', f'{dataset}_{metric}'], results_ttft.loc['duchess', f'{dataset}_{metric}']\n",
    "\n",
    "        lat_saving = (default_lat - duchess_lat) / default_lat\n",
    "        ttft_saving = (default_ttft - duchess_ttft) / default_ttft\n",
    "\n",
    "        print(f'{dataset}_{metric}: latency saving: {lat_saving:.2%}, ttft saving: {ttft_saving:.2%}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "825bf6ed",
   "metadata": {},
   "source": [
    "# Lat vs. QPM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "15f35d03",
   "metadata": {},
   "outputs": [],
   "source": [
    "qpms_dict = {\n",
    "    \"gsm8k\": [2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7],\n",
    "    \"mmlu\": [2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6],\n",
    "    \"math\":  [1, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2],\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "id": "b9d2e91c",
   "metadata": {},
   "outputs": [],
   "source": [
    "processing_times = dict()\n",
    "model_id = \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\n",
    "for dataset in ['gsm8k', 'mmlu', 'math']:\n",
    "    for method in ['default', 'duchess', 'shortm']:\n",
    "        if method == 'default':\n",
    "            df = postprocess(\n",
    "                pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_default.csv\"))\n",
    "            )\n",
    "        elif method == 'duchess':\n",
    "            df = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_duchess_vllm.csv\"))\n",
    "            df2 = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_torch.csv\"))\n",
    "            df = postprocess(df.merge(df2, on=\"uid\", how=\"inner\"))\n",
    "        elif method == 'shortm':\n",
    "            if os.path.isfile(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_shortm.csv\")):\n",
    "                df = postprocess(\n",
    "                    pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_shortm.csv\"))\n",
    "                )\n",
    "            else:\n",
    "                df = None\n",
    "        processing_times[(dataset, method)] = df\n",
    "\n",
    "for dataset in ['gsm8k', 'mmlu', 'math']:\n",
    "    for qpm in qpms_dict[dataset]:\n",
    "        output_name = os.path.join(\"schedule\", f\"{dataset}_{qpm}qpm_seed0.csv\")\n",
    "        if not os.path.isfile(output_name):\n",
    "            print('generating schedule')\n",
    "            schedule = generate_schedule(processing_times[(dataset, 'default')].unique_id.values.tolist(), qpm / 60, 0, True)\n",
    "            schedule.to_csv(os.path.join(\"schedule\", f\"{dataset}_{qpm}qpm_seed0.csv\"), index=False, header=True)\n",
    "\n",
    "results = dict()\n",
    "metrics = ['mean', 'median', 'tail']\n",
    "for dataset in ['gsm8k', 'mmlu', 'math']:\n",
    "    for metric in metrics:\n",
    "        default_numbers, duchess_numbers, shortm_numbers = list(), list(), list()\n",
    "        for qpm in qpms_dict[dataset]:\n",
    "            schedule = pd.read_csv(os.path.join(\"schedule\", f\"{dataset}_{qpm}qpm_seed0.csv\"))\n",
    "            default_lat = compute_latency(schedule.merge(processing_times[(dataset, 'default')], on=\"unique_id\", how=\"inner\"))\n",
    "            duchess_lat = compute_latency(schedule.merge(processing_times[(dataset, 'duchess')], on=\"unique_id\", how=\"inner\"))\n",
    "            if processing_times[(dataset, 'shortm')] is not None:\n",
    "                shortm_lat = compute_latency(schedule.merge(processing_times[(dataset, 'shortm')], on=\"unique_id\", how=\"inner\"))\n",
    "            else:\n",
    "                shortm_lat = None\n",
    "            if metric == 'mean':\n",
    "                default_numbers.append(default_lat.latency_s.mean())\n",
    "                duchess_numbers.append(duchess_lat.latency_s.mean())\n",
    "                if shortm_lat is not None:\n",
    "                    shortm_numbers.append(shortm_lat.latency_s.mean())\n",
    "            elif metric == 'median':\n",
    "                default_numbers.append(default_lat.latency_s.median())\n",
    "                duchess_numbers.append(duchess_lat.latency_s.median())\n",
    "                if shortm_lat is not None:\n",
    "                    shortm_numbers.append(shortm_lat.latency_s.median())\n",
    "            elif metric == 'tail':\n",
    "                default_numbers.append(np.percentile(default_lat.latency_s.values, 95))\n",
    "                duchess_numbers.append(np.percentile(duchess_lat.latency_s.values, 95))\n",
    "                if shortm_lat is not None:\n",
    "                    shortm_numbers.append(np.percentile(shortm_lat.latency_s.values, 95))\n",
    "        results[(dataset, metric)] = default_numbers, duchess_numbers, shortm_numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "c70fc383",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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L+VifPvtt6Xt27dLO3fulHbu3CkZDAZJkiQpPz9fuvPOO6WrV69KkiRJCxYskObPn2/1XIJQX1wx9/7xj39YzqHX66V7771X+vPPPy37HzhwQJo/f74lL9PS0qyey5WJll0Xp1QqGTt2LJs3b+bixYtltl2+fBlPT08A5PLyHwWj0cihQ4dQqVRlriRHjx6NRqOp8Hz+/v6MGDECAIVCgUwmK/ccuVxe4flujfnkyZPlWm4LCwvJyMggKCgIhUJh9RiC4KicMSdvzbURI0bg7e1tufuSkZHBmTNnaNOmDQMGDGDAgAGWfVauXEmrVq0ICgoCYNiwYXzzzTeUlJRYPZ8g1AdXyz2dTkd8fDyRkZGW1zd06FC+/vpry/O//vpr+vTpQ79+/RgwYABNmjSxei5XJiq7jcCIESMICwvj22+/LfP4999/z/333291v61bt3L33XczduxYli1bhiRJAAQEBFR6vsDAwDrH3K1bN7p3784333xT5vFVq1YxYcKEcs+/fPkyn376KW+99RYTJ07kyJEjAGRmZvLcc8/x6aef8vDDD7N+/XoANmzYwIQJE/j999954YUX6NGjB//+97/rHLcgVIcz5uTNZDIZkiRZKgfx8fEcOHCAoUOH8swzz5Cbm2t57o4dOwgPD7f8HRERQUFBASdOnLBpTIJQHa6Ue8XFxRiNRq5cuWLZ3qxZMxITEwG4ePEiBw8eZPr06dx5550cOHDAprE4E1HZbQQUCgXTp09n9erVlr5CBQUFZGZmEhERYXW/9evXM3r0aO677z5SU1PZvn17jc997do13n///TI/pRXRqjz00ENs27aNc+fOAWAymdizZw+DBg0q8zyTycRbb73F3/72N/75z38ybNgwnnnmGQwGA9988w3u7u48+eSTTJo0ic8++wwwty5duHCBP//8k5deeomvvvqK5cuXk5KSUuPXKAg15aw5WSouLo7CwkImT54MwGOPPcbBgwdZtGgRp06d4sknn7RUBjIyMvDz87Psq1KpUKvVZGRk1Dh2QagrV8o9X19funfvzuLFi9FqtRiNRk6ePImbmxsALVq0YM+ePWzevJmePXvy0EMPcfbs2RrH7QqU9g5AaBiTJ0/m008/ZenSpcyaNYuVK1cyadIkq88/e/YszZs3R6PR0K5dO3r16sWPP/7I7bffXqPzBgUF8fzzz5d5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",
      "text/plain": [
       "<Figure size 710x500 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_theme(style=\"whitegrid\", context=\"paper\", font_scale=1.1)\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold Italic.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Italic.ttf\")\n",
    "plt.rcParams.update({\n",
    "    \"axes.spines.top\": False, \"axes.spines.right\": False,\n",
    "    \"grid.alpha\": 0.25, \"legend.frameon\": False,\n",
    "    \"pdf.fonttype\": 42, \"ps.fonttype\": 42,\n",
    "    \"font.family\": \"Times New Roman\"\n",
    "})\n",
    "\n",
    "fig, axs = plt.subplots(3, 3, figsize=(7.1, 5))\n",
    "\n",
    "xticks_dict = copy.deepcopy(qpms_dict)\n",
    "\n",
    "xticklabels_dict = {\n",
    "    \"gsm8k\": [2, 3, 4, 5, 6, 7],\n",
    "    \"mmlu\": [2, 3, 4, 5, 6, 7],\n",
    "    \"math\": [1, 1.2, 1.4, 1.6, 1.8, 2, 2.2, 2.4],\n",
    "}\n",
    "\n",
    "title_dict = {\n",
    "    \"mean\": \"Mean\",\n",
    "    \"median\": \"P50\",\n",
    "    \"tail\": \"P95\",\n",
    "}\n",
    "\n",
    "for didx, dataset in enumerate(['gsm8k', 'mmlu', 'math']):\n",
    "    qpms = qpms_dict[dataset]\n",
    "    for midx, metric in enumerate(metrics):\n",
    "        default_numbers, duchess_numbers, shortm_numbers = results[(dataset, metric)]\n",
    "        ax = axs[didx, midx]\n",
    "        ax.plot(qpms, default_numbers, c='#3C5488', marker='^', label='Default SC', markersize=5, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", markevery=1)\n",
    "        if len(shortm_numbers) > 0:\n",
    "            ax.plot(qpms, shortm_numbers, c='#008000', marker='D', label='Short-m@k', markersize=5, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", markevery=1)\n",
    "        ax.plot(qpms, duchess_numbers, c='#E64B35', marker='s', label='DUCHESS (Ours)', markersize=5, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", markevery=1)\n",
    "        ax.set_title(f\"{dataset.upper()} {title_dict[metric]}\")\n",
    "        bottom_default, _ = ax.get_ylim()\n",
    "        # ax.set_xlabel(\"queries per minute\")\n",
    "        # ax.set_ylabel(f\"latency (s)\")\n",
    "        y_top = 1.4 * np.amax(duchess_numbers)\n",
    "        y_top = max(y_top, 1.02 * np.amin(default_numbers))\n",
    "        y_bottom = max(np.amin(duchess_numbers) - (y_top - np.amin(duchess_numbers)) / 19, 0)\n",
    "        ax.set_ylim(bottom=y_bottom, top=y_top)\n",
    "        # ax.set_xscale(\"log\")\n",
    "        ticklabels = list()\n",
    "        for xt in xticks_dict[dataset]:\n",
    "            if xt in xticklabels_dict[dataset]:\n",
    "                ticklabels.append(xt)\n",
    "            else:\n",
    "                ticklabels.append('')\n",
    "        ax.set_xticks(xticks_dict[dataset], labels=ticklabels, fontsize=10)\n",
    "        # ax.xaxis.set_minor_locator(FixedLocator(xticklabels_dict[dataset]))\n",
    "        # ax.tick_params(axis='x', which='minor', length=0, labelbottom=False)\n",
    "        # ax.grid(axis='x', which='minor')\n",
    "        ax.set_xlim(0.95 * np.amin(qpms), 1.05 * np.amax(qpms))\n",
    "\n",
    "fig.supxlabel(\"Request arrival rate (queries per minute)\", fontsize=11)\n",
    "fig.supylabel(\"Latency (s)\", fontsize=11)\n",
    "\n",
    "handles,labels=[],[]\n",
    "h,l=axs[1,1].get_legend_handles_labels()\n",
    "for hh,ll in zip(h,l):\n",
    "    if ll not in labels: handles.append(hh); labels.append(ll)\n",
    "fig.legend(handles,labels,loc=\"upper center\",ncol=len(labels),bbox_to_anchor=(0.5,1.06), fontsize=11, frameon=False)\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "sns.despine(fig)\n",
    "plt.show()\n",
    "fig.savefig(\"figs/iclr/latency_qpm.pdf\", bbox_inches=\"tight\", pad_inches=0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c8b1533a",
   "metadata": {},
   "source": [
    "# Per-component overhead breakdown"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "09c52d35",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns.set_theme(style=\"whitegrid\", context=\"paper\", font_scale=1.1)\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold Italic.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Italic.ttf\")\n",
    "plt.rcParams.update({\n",
    "    \"axes.spines.top\": False, \"axes.spines.right\": False,\n",
    "    \"grid.alpha\": 0.25, \"legend.frameon\": False,\n",
    "    \"pdf.fonttype\": 42, \"ps.fonttype\": 42,\n",
    "    \"font.family\": \"Times New Roman\"\n",
    "})\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"axes.spines.top\": False, \"axes.spines.right\": False,\n",
    "    \"grid.alpha\": 0.25, \"legend.frameon\": False,\n",
    "    \"pdf.fonttype\": 42, \"ps.fonttype\": 42,\n",
    "    \"font.family\": \"Times New Roman\"\n",
    "})\n",
    "\n",
    "labels_map = {\n",
    "    \"queueing_time_s\": \"Queueing\",\n",
    "    \"prediction_time_s\": \"Prediction\",\n",
    "    \"decode_time_s\": \"LLM inference\",\n",
    "    \"probe_time_s\": \"Answer extraction\",\n",
    "}\n",
    "\n",
    "color_map = {\n",
    "    \"queueing_time_s\": \"#56B4E9\",   # sky blue\n",
    "    \"prediction_time_s\": \"#E69F00\", # orange\n",
    "    \"decode_time_s\": \"#009E73\",     # teal\n",
    "    \"probe_time_s\": \"#CC79A7\",      # purple-pink\n",
    "}\n",
    "\n",
    "labels = {\n",
    "    \"decode_time_s\": \"LLM inference\",\n",
    "    \"probe_time_s\": \"answer extraction\",\n",
    "    \"prediction_time_s\": \"branch correctness prediction\",\n",
    "    \"queueing_time_s\": \"queueing delay\"\n",
    "}\n",
    "order = [\"gsm8k\", \"mmlu\", \"math\"]\n",
    "\n",
    "default_bars = list()\n",
    "duchess_bars = list()\n",
    "\n",
    "pred, extract, llm = list(), list(), list()\n",
    "\n",
    "qpm_per_dataset = {\n",
    "    \"gsm8k\": 2,\n",
    "    \"mmlu\": 2,\n",
    "    \"math\": 1,\n",
    "}\n",
    "\n",
    "for dataset in [\"gsm8k\", \"mmlu\", \"math\"]:\n",
    "    qpm = qpm_per_dataset[dataset]\n",
    "    schedule = pd.read_csv(os.path.join(\"schedule\", f\"{dataset}_{qpm}qpm_seed0.csv\"))\n",
    "    duchess_df = processing_times[(dataset, \"duchess\")]\n",
    "    pred.append(duchess_df.prediction_time_s.mean())\n",
    "    extract.append(duchess_df.probe_time_s.mean())\n",
    "    llm.append(duchess_df.decode_time_s.mean())\n",
    "\n",
    "pred, extract, llm = np.array(pred), np.array(extract), np.array(llm)\n",
    "total = pred + extract + llm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "id": "a7821d65",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasets = [\"GSM8K\", \"MMLU\", \"MATH\"]\n",
    "x = np.arange(len(datasets))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "id": "874f5f89",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.00546368, 0.00223571, 0.00530438]),\n",
       " array([0.284547  , 0.17816454, 0.27789415]),\n",
       " array([ 7.49952493, 10.12462841, 30.97411298]))"
      ]
     },
     "execution_count": 145,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pred, extract, llm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "id": "041a157f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 7.7895356 , 10.30502866, 31.25731152])"
      ]
     },
     "execution_count": 146,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d544b4a",
   "metadata": {},
   "source": [
    "# Complexity-aware scheduling w/ FCFS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "b81ab41a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_latency_with_ordering(schedule_wtime, order_col='level'):\n",
    "    ret = schedule_wtime.copy()\n",
    "    ret.set_index(\"unique_id\", inplace=True)\n",
    "    ret['start_time_s'] = 0.0\n",
    "    ret['finish_time_s'] = -1.0\n",
    "    curr_time = ret.arrival_time_s.min()\n",
    "    while ret['finish_time_s'].min() == -1:\n",
    "        curr_time = max(curr_time, ret[ret['finish_time_s'] == -1].arrival_time_s.min())\n",
    "        queued_jobs = ret[(ret['finish_time_s'] == -1) & (ret['arrival_time_s'] <= curr_time)]\n",
    "        selected_job = queued_jobs.sort_values(by=order_col, ascending=True).iloc[0]\n",
    "        ret.loc[selected_job.name, 'start_time_s'] = curr_time\n",
    "        ret.loc[selected_job.name, 'finish_time_s'] = curr_time + selected_job.processing_time_s\n",
    "        curr_time = curr_time + selected_job.processing_time_s\n",
    "    ret['queueing_time_s'] = ret['start_time_s'] - ret['arrival_time_s']\n",
    "    ret['latency_s'] = ret['finish_time_s'] - ret['arrival_time_s']\n",
    "    ret.reset_index(inplace=True)\n",
    "    return ret\n",
    "\n",
    "\n",
    "\n",
    "def compute_latency_with_predicted_ordering(schedule_wtime, order_col='level_predict'):\n",
    "    ret = schedule_wtime.copy()\n",
    "    ret.set_index(\"unique_id\", inplace=True)\n",
    "    ret['start_time_s'] = 0.0\n",
    "    ret['finish_time_s'] = -1.0\n",
    "    curr_time = ret.arrival_time_s.min()\n",
    "    done_predictions = set()\n",
    "    while ret['finish_time_s'].min() == -1:\n",
    "        curr_time = max(curr_time, ret[ret['finish_time_s'] == -1].arrival_time_s.min())\n",
    "        queued_jobs = ret[(ret['finish_time_s'] == -1) & (ret['arrival_time_s'] <= curr_time)]\n",
    "        pred_overhead = 0\n",
    "        for unique_id, job in queued_jobs.iterrows():\n",
    "            if unique_id not in done_predictions:\n",
    "                pred_overhead += job['prediction_time'] + job['prefill_time_s']\n",
    "                done_predictions.add(unique_id)\n",
    "        selected_job = queued_jobs.sort_values(by=order_col, ascending=True).iloc[0]\n",
    "        ret.loc[selected_job.name, 'start_time_s'] = curr_time\n",
    "        ret.loc[selected_job.name, 'finish_time_s'] = curr_time + selected_job.processing_time_s + pred_overhead - selected_job.prefill_time_s\n",
    "        curr_time = curr_time + selected_job.processing_time_s + pred_overhead - selected_job.prefill_time_s\n",
    "    ret['queueing_time_s'] = ret['start_time_s'] - ret['arrival_time_s']\n",
    "    ret['latency_s'] = ret['finish_time_s'] - ret['arrival_time_s']\n",
    "    ret.reset_index(inplace=True)\n",
    "    return ret"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "637e3141",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"math\"\n",
    "model_id = \"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"\n",
    "duchess = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_duchess_vllm.csv\"))\n",
    "duchess2 = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_torch.csv\"))\n",
    "prefilling = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], MODEL_IDS[model_id], \"latency_traces\", \"branch10\", \"latency_prefill.csv\"))\n",
    "duchess = duchess.merge(duchess2, on=\"uid\", how=\"inner\").merge(prefilling, on=\"uid\", how=\"inner\")\n",
    "duchess = postprocess(duchess)\n",
    "math_df = pd.read_csv(os.path.join(DSET_TO_DIR[dataset], \"math3k.csv\"))\n",
    "duchess = duchess.merge(math_df[[\"unique_id\", \"level\"]], on=\"unique_id\", how=\"inner\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "64fa6ea5",
   "metadata": {},
   "outputs": [],
   "source": [
    "SELECTED_LAYER = 14\n",
    "prompt_difficulty_preds = pd.read_csv(\n",
    "    os.path.join(\n",
    "        MATH_DIR,\n",
    "        MODEL_IDS[\"deepseek-ai/DeepSeek-R1-Distill-Llama-8B\"],\n",
    "        \"difficulty_prediction\",\n",
    "        f\"L{SELECTED_LAYER}_mlp\",\n",
    "        \"best_epoch_test_results.csv\"\n",
    "    )\n",
    ")\n",
    "prompt_difficulty_preds.head()\n",
    "duchess_w_pred = duchess.merge(prompt_difficulty_preds[[\"unique_id\", \"level_predict\", \"prediction_time\"]], on=\"unique_id\", how=\"inner\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "f12e589a",
   "metadata": {},
   "outputs": [],
   "source": [
    "qpms_dict = {\n",
    "    \"math\": [1.5, 1.7, 1.9, 2.1, 2.3, 2.5],\n",
    "}\n",
    "\n",
    "results_fcfs = dict()\n",
    "metrics = ['mean', 'median']\n",
    "for dataset in ['math']:\n",
    "    for metric in metrics:\n",
    "        duchess_numbers = list()\n",
    "        for qpm in qpms_dict[dataset]:\n",
    "            schedule = generate_schedule(processing_times[(dataset, 'default')].unique_id.values.tolist(), qpm / 60, 0, True)\n",
    "            duchess_lat = compute_latency(schedule.merge(duchess, on=\"unique_id\", how=\"inner\"))\n",
    "            if metric == 'mean':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.mean())\n",
    "            elif metric == 'median':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.median())\n",
    "            elif metric == 'tail':\n",
    "                duchess_numbers.append(np.percentile(duchess_lat.latency_s.values, 95))\n",
    "        results_fcfs[(dataset, metric)] = duchess_numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "404101d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_order = dict()\n",
    "for dataset in ['math']:\n",
    "    for metric in metrics:\n",
    "        duchess_numbers = list()\n",
    "        for qpm in qpms_dict[dataset]:\n",
    "            schedule = generate_schedule(processing_times[(dataset, 'default')].unique_id.values.tolist(), qpm / 60, 0, True)\n",
    "            duchess_lat = compute_latency_with_ordering(\n",
    "                schedule.merge(duchess, on=\"unique_id\", how=\"inner\"),\n",
    "                \"level\"\n",
    "            )\n",
    "            if metric == 'mean':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.mean())\n",
    "            elif metric == 'median':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.median())\n",
    "            elif metric == 'tail':\n",
    "                duchess_numbers.append(np.percentile(duchess_lat.latency_s.values, 95))\n",
    "        results_order[(dataset, metric)] = duchess_numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "177c5fcd",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_order_pred = dict()\n",
    "for dataset in ['math']:\n",
    "    for metric in metrics:\n",
    "        duchess_numbers = list()\n",
    "        for qpm in qpms_dict[dataset]:\n",
    "            schedule = generate_schedule(processing_times[(dataset, 'default')].unique_id.values.tolist(), qpm / 60, 0, True)\n",
    "            duchess_lat = compute_latency_with_predicted_ordering(\n",
    "                schedule.merge(duchess_w_pred, on=\"unique_id\", how=\"inner\"),\n",
    "                \"level_predict\"\n",
    "            )\n",
    "            if metric == 'mean':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.mean())\n",
    "            elif metric == 'median':\n",
    "                duchess_numbers.append(duchess_lat.latency_s.median())\n",
    "            elif metric == 'tail':\n",
    "                duchess_numbers.append(np.percentile(duchess_lat.latency_s.values, 95))\n",
    "        results_order_pred[(dataset, metric)] = duchess_numbers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "e8a64833",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 280x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_theme(style=\"whitegrid\", context=\"paper\", font_scale=1.1)\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Bold Italic.ttf\")\n",
    "fm.fontManager.addfont(\"font-times-new-roman/Times New Roman - Italic.ttf\")\n",
    "plt.rcParams.update({\n",
    "    \"axes.spines.top\": False, \"axes.spines.right\": False,\n",
    "    \"grid.alpha\": 0.25, \"legend.frameon\": False,\n",
    "    \"pdf.fonttype\": 42, \"ps.fonttype\": 42,\n",
    "    \"font.family\": \"Times New Roman\"\n",
    "})\n",
    "\n",
    "xticks_dict = {\n",
    "    \"math\": [1.5, 1.7, 1.9, 2.1, 2.3, 2.5],\n",
    "}\n",
    "\n",
    "xticklabels_dict = {\n",
    "    \"math\": [1.5, 1.7, 1.9, 2.1, 2.3, 2.5],\n",
    "}\n",
    "\n",
    "fig, ax = plt.subplots(1, 1, figsize=(2.8, 1.5))\n",
    "\n",
    "for didx, dataset in enumerate(['math', ]):\n",
    "    qpms = qpms_dict[dataset]\n",
    "    for midx, metric in enumerate(['mean']):\n",
    "        fcfs_numbers = results_fcfs[(dataset, metric)]\n",
    "        order_numbers = results_order[(dataset, metric)]\n",
    "        order_pred_numbers = results_order_pred[(dataset, metric)]\n",
    "        ax.plot(qpms, fcfs_numbers, c='#3C5488', marker='^', label='FCFS', markersize=6, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", alpha=0.8)\n",
    "        ax.plot(qpms, order_pred_numbers, c='#00A087', marker='D', label='Complexity-aware (predicted)', markersize=6, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", alpha=0.8)\n",
    "        ax.plot(qpms, order_numbers, c='#E64B35', marker='s', label='Complexity-aware', markersize=6, linewidth=1.3, markeredgewidth=0.8, markeredgecolor=\"gray\", alpha=0.8)\n",
    "        # ax.set_title(f\"{dataset.upper()} {title_dict[metric]}\")\n",
    "        bottom_default, _ = ax.get_ylim()\n",
    "        # ax.set_xlabel(\"queries per minute\")\n",
    "        # ax.set_ylabel(f\"latency (s)\")\n",
    "        y_top = 1.04 * np.amax(fcfs_numbers)\n",
    "        y_bottom = max(np.amin(fcfs_numbers) - (y_top - np.amin(order_numbers)) / 19, 0)\n",
    "        # ax.set_ylim(bottom=y_bottom, top=y_top)\n",
    "        # ax.set_xscale(\"log\")\n",
    "        ax.set_xlim(1.5 * 0.98, 2.5 * 1.02)\n",
    "        ax.set_xticks(xticks_dict[dataset])\n",
    "        ticklabels = list()\n",
    "        for xt in xticks_dict[dataset]:\n",
    "            if xt in xticklabels_dict[dataset]:\n",
    "                ticklabels.append(xt)\n",
    "            else:\n",
    "                ticklabels.append('')\n",
    "        ax.set_xticklabels(ticklabels, fontsize=10)\n",
    "        # ax.set_yscale(\"log\")\n",
    "        # ax.set_xticklabels([round(q, 1) for q in qpms[::2]], fontsize=10)\n",
    "        ax.xaxis.set_minor_locator(FixedLocator(xticklabels_dict[dataset]))\n",
    "        ax.grid(axis='x', which='minor')\n",
    "        ax.tick_params(axis='x', which='minor', length=0, labelbottom=False)\n",
    "\n",
    "ax.set_yticks([0, 500, 1000, 1500, 2000], labels=[0, 500, 1000, 1500, 2000], fontsize=10)\n",
    "ax.set_xlabel(\"Request arrival rate (queries per minute)\", fontsize=12)\n",
    "ax.set_ylabel(\"Mean latency (s)\", fontsize=12)\n",
    "\n",
    "handles,labels=[],[]\n",
    "h,l=ax.get_legend_handles_labels()\n",
    "for hh,ll in zip(h,l):\n",
    "    if ll not in labels: handles.append(hh); labels.append(ll)\n",
    "reordered_labels = ['FCFS', 'Complexity-aware (predicted)', 'Complexity-aware']\n",
    "reordered_handles = [handles[labels.index(ll)] for ll in reordered_labels]\n",
    "fig.legend(reordered_handles,reordered_labels,loc=\"upper center\",ncol=3,bbox_to_anchor=(0.5,1.26), fontsize=11, frameon=False)\n",
    "# fig.legend(handles,labels,loc=\"upper left\",ncol=1, borderpad=0, fontsize=10, frameon=False, bbox_to_anchor=(0.23, 1))\n",
    "\n",
    "fig.tight_layout(pad=0)\n",
    "plt.show()\n",
    "fig.savefig(\"figs/iclr/latency_math_scheduling.pdf\", bbox_inches=\"tight\", pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "cbd2f896",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Difficulty 1: mean: 13.812323188904983 median: 8.434168500425994\n",
      "Difficulty 2: mean: 18.421758664610447 median: 12.402586212537251\n",
      "Difficulty 3: mean: 25.817119053091993 median: 18.76014928180748\n",
      "Difficulty 4: mean: 33.59782700970936 median: 26.715922996604583\n",
      "Difficulty 5: mean: 47.3569186295505 median: 50.481550216633835\n"
     ]
    }
   ],
   "source": [
    "# Print processing time per request difficulty\n",
    "# to motivate scheduling\n",
    "\n",
    "gb = duchess_w_pred.groupby(\"level\")\n",
    "for level, subdf in gb:\n",
    "    print(\"Difficulty {}: mean: {} median: {}\".format(level, subdf.processing_time_s.mean(), subdf.processing_time_s.median()))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f460ba91",
   "metadata": {},
   "source": [
    "### Confusion Matrix for request difficulty prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "1fa1efa7",
   "metadata": {},
   "outputs": [],
   "source": [
    "level_gt, level_pred = duchess_w_pred.level.values, duchess_w_pred.level_predict.values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "d6362dc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 180x180 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.patches import Rectangle\n",
    "\n",
    "cm = confusion_matrix(level_gt, level_pred, normalize=\"true\")\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(1.8, 1.8))\n",
    "disp = ConfusionMatrixDisplay(confusion_matrix=cm, display_labels=[1, 2, 3, 4, 5])\n",
    "disp.plot(ax=ax, cmap=\"Blues\", colorbar=False, values_format=\".2f\")\n",
    "\n",
    "# Resize display text\n",
    "for txt in disp.text_.ravel():\n",
    "    txt.set_fontsize(9)\n",
    "\n",
    "# Axis labels and ticks\n",
    "ax.set_xlabel(\"Predicted complexity\", fontsize=10)\n",
    "ax.set_ylabel(\"Actual complexity\", fontsize=10)\n",
    "ax.tick_params(axis=\"both\", labelsize=9)\n",
    "\n",
    "# Remove default grid\n",
    "ax.grid(False)\n",
    "\n",
    "\n",
    "fig.tight_layout(pad=0)\n",
    "plt.show()\n",
    "fig.savefig(\"figs/iclr/math_difficulty_cm.pdf\", bbox_inches=\"tight\", pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "2d33ab21",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy:  0.4213709677419355\n",
      "Balanced Accuracy:  0.3923320854805553\n"
     ]
    }
   ],
   "source": [
    "from sklearn.metrics import accuracy_score, balanced_accuracy_score\n",
    "\n",
    "print(\"Accuracy: \", accuracy_score(level_gt, level_pred))\n",
    "print(\"Balanced Accuracy: \", balanced_accuracy_score(level_gt, level_pred))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "3f2daaa5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "97.94021813907548 87.73356695883318 -10.421307379312573\n",
      "150.7033189264623 124.63681926658136 -17.29656642306626\n",
      "403.5911869993729 285.60399582455995 -29.234332903061205\n",
      "891.4774760784159 594.0435366778291 -33.36415640123519\n",
      "1469.4744947660167 962.1135275935599 -34.52669433730073\n",
      "1968.4630887455473 1285.9684037553243 -34.67144946188247\n"
     ]
    }
   ],
   "source": [
    "# FCFS vs. complexity-ware with groundtruth\n",
    "\n",
    "for f, o in zip(fcfs_numbers, order_numbers):\n",
    "    print(f, o, 100 * (o - f) / f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "4c9694aa",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "97.94021813907548 84.02165932774669 -14.211280182737992\n",
      "150.7033189264623 120.61228556961021 -19.967067461556972\n",
      "403.5911869993729 294.192612713311 -27.106284232671282\n",
      "891.4774760784159 626.6353024033739 -29.708229403627247\n",
      "1469.4744947660167 1039.700827679844 -29.246759206569642\n",
      "1968.4630887455473 1401.2370228865339 -28.815682097472937\n"
     ]
    }
   ],
   "source": [
    "# FCFS vs. complexity-aware with perdictions\n",
    "\n",
    "for f, o in zip(fcfs_numbers, order_pred_numbers):\n",
    "    print(f, o, 100 * (o - f) / f)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "reasoning",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
