{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd\n",
    "import pickle as pkl\n",
    "import polars as pl\n",
    "import policy\n",
    "import random\n",
    "import seaborn as sns\n",
    "from config import *\n",
    "from create_tensor import load_metadata\n",
    "from matplotlib import font_manager as fm\n",
    "from pathlib import Path\n",
    "from sklearn.metrics import average_precision_score, precision_recall_curve\n",
    "from tqdm.notebook import tqdm\n",
    "from utils import load_test_predictions, load_test_prompt_predictions, load_val_predictions, process_math_id\n",
    "\n",
    "\n",
    "def get_ta_plot_and_errbars(exp_list):\n",
    "\n",
    "    t, a, t_err, a_err = list(), list(), list(), list()\n",
    "    \n",
    "    for exp in exp_list:\n",
    "        t_raw = [df.tokens.mean() for df in exp]\n",
    "        a_raw = [df.accuracy.mean() for df in exp]\n",
    "        t.append(np.mean(t_raw))\n",
    "        a.append(np.mean(a_raw))\n",
    "        t_err.append(np.std(t_raw))\n",
    "        a_err.append(np.std(a_raw))\n",
    "    \n",
    "    return t, a, t_err, a_err\n",
    "\n",
    "\n",
    "os.makedirs('figs', exist_ok=True)\n",
    "\n",
    "marker_dict = {\n",
    "    \"Default SC\": \"^\",\n",
    "    \"Dynasor\": \"o\",\n",
    "    \"Short-m@k\": \"D\",\n",
    "    \"Perfect prediction\": \"1\",\n",
    "    \"DUCHESS (Ours)\": \"s\"\n",
    "}\n",
    "\n",
    "color_dict = {\n",
    "    \"Default SC\": \"red\",\n",
    "    \"Dynasor\": \"blue\",\n",
    "    \"Short-m@k\": \"green\",\n",
    "    \"Perfect prediction\": \"orange\",\n",
    "    \"DUCHESS (Ours)\": \"purple\"\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Overall"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 710x240 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set_theme(style=\"whitegrid\", context=\"paper\", font_scale=1)\n",
    "sns.set_palette([\"#4DBBD5\",\"#00A087\",\"#3C5488\",\"#E64B35\",])\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({\"axes.spines.top\":False,\"axes.spines.right\":False,\"axes.linewidth\":1.0,\"grid.alpha\":0.25,\n",
    "                     \"legend.frameon\":False,\"pdf.fonttype\":42,\"ps.fonttype\":42, \"font.family\": \"Times New Roman\"})\n",
    "\n",
    "DATASETS=[\"gsm8k\",\"mmlu\",\"math\"]\n",
    "METHODS=[\"baseline\",\"dynasor\",\"shortm\",\"greedyprob\"]\n",
    "LABEL={\"baseline\":\"Default SC\",\"dynasor\":\"Dynasor\",\"shortm\":\"Short-m@k\",\"greedyprob\":\"DUCHESS (Ours)\"}\n",
    "MARK={\"Default SC\":\"^\",\"Dynasor\":\"o\",\"Short-m@k\":\"D\",\"DUCHESS (Ours)\":\"s\"}\n",
    "COLOR={\"Default SC\":\"#3C5488\",\"Dynasor\":\"#4DBBD5\",\"Short-m@k\":\"#00A087\",\"DUCHESS (Ours)\":\"#E64B35\"}\n",
    "\n",
    "AX={\n",
    "    \"gsm8k\":dict(ylim=(0.74,0.81),yticks=[0.74,0.75,0.76,0.77,0.78,0.79,0.80,0.81],xlim=(2000,8000),xticks=list(range(2000,9000,1000))),\n",
    "    \"mmlu\": dict(ylim=(0.62,0.72),yticks=[0.62,0.64,0.66,0.68,0.70,0.72],xlim=(2000,10000),xticks=list(range(2000,11000,1000))),\n",
    "    \"math\": dict(ylim=(0.65,0.75),yticks=[0.65,0.67,0.69,0.71,0.73,0.75],xlim=(5000,27000),xticks=list(range(5000,28000,2000))),\n",
    "}\n",
    "TIT={\"gsm8k\":\"GSM8K\",\"mmlu\":\"MMLU\",\"math\":\"MATH\"}\n",
    "\n",
    "def load_logs(root=\"figs\", model=\"dsk-r1-llama\"):\n",
    "    return { (d,m): pkl.load(open(Path(root,d,model,f\"{m}_exp.pkl\"),\"rb\")) for d in DATASETS for m in METHODS }\n",
    "\n",
    "def agg(exp_list):\n",
    "    t=[df.tokens.mean() for df in exp_list]; a=[df.accuracy.mean() for df in exp_list]\n",
    "    n=max(len(t),1); te=1.96*np.std(t,ddof=1)/np.sqrt(n) if n>1 else 0.0; ae=1.96*np.std(a,ddof=1)/np.sqrt(n) if n>1 else 0.0\n",
    "    return np.mean(t),np.mean(a),te,ae\n",
    "\n",
    "def series(exp_runs):\n",
    "    T,A,Te,Ae=map(np.array,zip(*[agg(r) for r in exp_runs])); idx=np.argsort(T); return T[idx],A[idx],Te[idx],Ae[idx]\n",
    "\n",
    "def fmt_axes(ax, d):\n",
    "    ax.set(**AX[d]); ax.grid(True, alpha=0.25)\n",
    "    from matplotlib.ticker import ScalarFormatter\n",
    "    sf=ScalarFormatter(useMathText=True); sf.set_powerlimits((3,3)); ax.xaxis.set_major_formatter(sf)\n",
    "\n",
    "Path(\"figs/iclr\").mkdir(parents=True, exist_ok=True)\n",
    "logs=load_logs()\n",
    "\n",
    "dataset_token_savings = dict()\n",
    "target_acc = dict()\n",
    "\n",
    "fig, axs = plt.subplots(1,3, figsize=(7.1,2.4), constrained_layout=True)\n",
    "for ax,d in zip(axs, DATASETS):\n",
    "    max_a=base_t=None\n",
    "    for m in METHODS:\n",
    "        label=LABEL[m]; T,A,Te,Ae=series(logs[(d,m)])\n",
    "        ax.errorbar(T,A,xerr=Te,yerr=Ae,fmt='none',ecolor=COLOR[label],capsize=2.5,capthick=1.2,alpha=0.9)\n",
    "        ax.plot(T,A,'-',marker=MARK[label],markersize=5,linewidth=1.3,color=COLOR[label],markeredgewidth=0.8,markeredgecolor=\"gray\",label=label)\n",
    "        if m==\"baseline\": j=np.argmax(A); max_a=A[j]; base_t=T[j]\n",
    "        if m==\"greedyprob\" and max_a is not None:\n",
    "            ok=A>=0.999*max_a-1e-12\n",
    "            if np.any(ok):\n",
    "                t_ours=np.min(T[ok])\n",
    "        \n",
    "        if m == \"baseline\":\n",
    "            target_acc[d] = np.amax(A) * 0.999\n",
    "            dataset_token_savings[d] = np.amin(T[np.argmax(A)])\n",
    "        elif m == \"greedyprob\":\n",
    "            baseline_t = dataset_token_savings[d]\n",
    "            ours_t = np.amin(T[A >= target_acc[d]])\n",
    "            dataset_token_savings[d] = ours_t, baseline_t\n",
    "        \n",
    "    ax.set_title(TIT[d],fontsize=11, pad=6); fmt_axes(ax,d)\n",
    "\n",
    "fig.supxlabel(\"Computational cost (average tokens per request)\", fontsize=11)\n",
    "# fig.supylabel(\"Accuracy\", fontsize=11)\n",
    "axs[0].set_ylabel(\"Accuracy\", fontsize=11)\n",
    "\n",
    "handles,labels=[],[]\n",
    "for ax in axs:\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",
    "fig.legend(handles,labels,loc=\"upper center\",ncol=len(labels),bbox_to_anchor=(0.5,1.14), fontsize=11, frameon=False)\n",
    "\n",
    "sns.despine(fig)\n",
    "plt.show()\n",
    "fig.savefig(\"figs/iclr/token_accuracy.pdf\", bbox_inches=\"tight\", pad_inches=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gsm8k: -42.38%\n",
      "mmlu: -62.95%\n",
      "math: -46.23%\n"
     ]
    }
   ],
   "source": [
    "for dname, vals in dataset_token_savings.items():\n",
    "    ours_t, baseline_t = vals\n",
    "    pct_savings = 100 * (ours_t - baseline_t) / baseline_t\n",
    "    print(f\"{dname}: {pct_savings:.2f}%\")"
   ]
  }
 ],
 "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": 2
}
