{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import matthews_corrcoef as mcc_fn\n",
    "from sklearn.metrics import accuracy_score as acc_fn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot \n",
    "num_classes = 7\n",
    "split_idx = 0\n",
    "seed = 604\n",
    "\n",
    "exp_dirs = {\n",
    "    'SATzilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0604_satzilla_mlp\",   # Raw logs in baselines/ directory\n",
    "    'GCN-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0608_solv-none\",\n",
    "    'Hetero-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0802_hetero_logits\",\n",
    "    'Hetero-Nodezilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0808_hetero_satzilla_feat\"\n",
    "}\n",
    "\n",
    "res = {}\n",
    "\n",
    "for exp_name, exp_dir in exp_dirs.items():\n",
    "    run_dir = os.path.join(exp_dir, f\"seed_{seed}_split_{split_idx}\")\n",
    "    pred_filepath = os.path.join(run_dir, 'test_pred_probs.csv')\n",
    "    label_filepath = os.path.join(run_dir, 'test_labels.csv')\n",
    "\n",
    "    if not os.path.isfile(pred_filepath):\n",
    "        continue\n",
    "\n",
    "    preds = pd.read_csv(pred_filepath, index_col=False).to_numpy()\n",
    "    # Note that the labels saved in sat_selection_light has variables other than runtime\n",
    "    labels = pd.read_csv(label_filepath, index_col=False).to_numpy()\n",
    "    if labels.shape[1] == 10:\n",
    "        runtime = labels[:, 2:-1]\n",
    "\n",
    "    if num_classes == 5:   # Remove kissat3 and bulky\n",
    "        runtime = np.concatenate([labels[:, 1:5], labels[:, 6:]], axis=-1)\n",
    "\n",
    "    pred_idx =  preds.argmax(axis=1)\n",
    "    tgt_idx = runtime.argmin(axis=1)\n",
    "\n",
    "    len_data = preds.shape[0]\n",
    "    pred_rt = runtime[torch.arange(len_data), pred_idx] \n",
    "    tgt_rt = runtime.min(axis=1)\n",
    "\n",
    "    rt_delta = pred_rt - tgt_rt\n",
    "\n",
    "    rt_delta_cost = rt_delta[rt_delta>0]\n",
    "    # cost_mean = rt_delta_cost.mean()\n",
    "    # cost_std = rt_delta_cost.std()\n",
    "\n",
    "    res[exp_name] = rt_delta_cost\n",
    "\n",
    "plt.figure()\n",
    "exp_names = list(res.keys())\n",
    "values = list(res.values())\n",
    "ax = sns.boxplot(values)\n",
    "ax.set_xticklabels(exp_names)\n",
    "\n",
    "means = [v.mean() for v in values]\n",
    "stds = [v.std() for v in values]\n",
    "for xtick in ax.get_xticks():\n",
    "    ax.text(xtick, means[xtick],f\"{means[xtick]:.3f}({stds[xtick]:.3f})\", \n",
    "            horizontalalignment='center',size='x-small',color='w',weight='semibold')\n",
    "\n",
    "plt.title(f\"Cost of wrong prediction\")\n",
    "plt.xlabel('Exp_name')\n",
    "plt.ylabel('Runtime (s)')\n",
    "# plot_savepath = pred_filepath.split('.')[0]+'.png' \n",
    "# plt.savefig(plot_savepath)\n",
    "plt.show()\n",
    "plt.close()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sat",
   "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.2"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
