{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6c475057",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4aa665a4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from uncalibrated_reasoning.utils import get_cache_dir\n",
    "from collections import defaultdict\n",
    "import seaborn as sns\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import roc_auc_score\n",
    "from pathlib import Path\n",
    "import scipy.stats as st"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "633f1967",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_num(x):\n",
    "    try:\n",
    "        x = float(x)\n",
    "        if x < 1:\n",
    "            x = 1\n",
    "        \n",
    "        if x > 99:\n",
    "            x = 99\n",
    "        return x\n",
    "    except:\n",
    "        return None\n",
    "    \n",
    "def expected_calibration_error(targets, preds, n_bins=10):\n",
    "    df = pd.DataFrame({\"pred\": preds, \"target\": targets})\n",
    "    df[\"pred_bin\"] = pd.cut(df[\"pred\"], np.linspace(0, 1, n_bins+1))\n",
    "    bin_mean_pred = df.groupby(\"pred_bin\", observed=True)[\"pred\"].mean()\n",
    "    bin_mean_target = df.groupby(\"pred_bin\", observed=True)[\"target\"].mean()\n",
    "    bin_counts = df.groupby(\"pred_bin\", observed=True)[\"target\"].count()\n",
    "\n",
    "    bin_counts_normalized = bin_counts / df.shape[0]\n",
    "\n",
    "    ece = (bin_counts_normalized * (bin_mean_pred - bin_mean_target).abs())\n",
    "    ece = ece.sum()\n",
    "    return ece\n",
    "\n",
    "def accuracy_mle(targets, preds, n_bins=10):\n",
    "    n_correct = 0\n",
    "    n_correct += (targets[preds > 0.5] == True).sum()\n",
    "    n_correct += (targets[preds < 0.5] == False).sum()\n",
    "    n_correct += 0.5 * (preds == 0.5).sum()\n",
    "    return n_correct / preds.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "55d8294b",
   "metadata": {},
   "outputs": [],
   "source": [
    "use_paper_data = True\n",
    "if use_paper_data:\n",
    "    cache_dir = Path(\"../../paper_data/\")\n",
    "else:\n",
    "    cache_dir = get_cache_dir()\n",
    "outdir = Path(\"images/\")\n",
    "outdir.mkdir(exist_ok=True, parents=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b48b53da",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_preds(experiment_name, step, data_key, prompt_key, split):\n",
    "    df = []\n",
    "    basedir = cache_dir / \"experiments\" / experiment_name / f\"global_step_{step}\" / data_key / f\"{prompt_key}-split-{split}\"\n",
    "    for path in sorted(basedir.iterdir()):\n",
    "        df.append(pd.read_parquet(path))\n",
    "    df = pd.concat(df)\n",
    "    df[\"answer_num\"] = df[\"answer\"].apply(get_num)\n",
    "    df = df.dropna()\n",
    "    thresh = np.linspace(0, 100, 11)\n",
    "    df[\"answer_bin\"] = pd.cut(df[\"answer_num\"], thresh, labels=False).astype(int)\n",
    "    df[\"answer_bin_val\"] = thresh[df[\"answer_bin\"].to_numpy()] + 5\n",
    "    return df\n",
    "\n",
    "def load_zero_shot_preds(data_key, prompt_key, split):\n",
    "    df = []\n",
    "    basedir = cache_dir / \"baselines\" / data_key / f\"{prompt_key}-split-{split}\"\n",
    "    for path in sorted(basedir.iterdir()):\n",
    "        df.append(pd.read_parquet(path))\n",
    "    df = pd.concat(df)\n",
    "    df[\"answer_num\"] = df[\"answer\"].apply(get_num)\n",
    "    df = df.dropna()\n",
    "    thresh = np.linspace(0, 100, 11)\n",
    "    df[\"answer_bin\"] = pd.cut(df[\"answer_num\"], thresh, labels=False).astype(int)\n",
    "    df[\"answer_bin_val\"] = thresh[df[\"answer_bin\"].to_numpy()] + 5\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "5a0a11a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"replogle_k562_essential_cnmf\"\n",
    "prompt = \"hit_probability_v2\"\n",
    "split = \"test\"\n",
    "\n",
    "dfs = {}\n",
    "dfs[\"GRPO-offline\"] = load_preds(\"final_grpo\", 180, dataset, prompt, split)\n",
    "dfs[\"GRPO_no_std-offline\"] = load_preds(\"final_grpo_no_std\", 180, dataset, prompt, split)\n",
    "dfs[\"RLOO-offline\"] = load_preds(\"final_rloo\", 180, dataset, prompt, split)\n",
    "dfs[\"PPO-offline\"] = load_preds(\"final_ppo\", 180, dataset, prompt, split)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4eee5787",
   "metadata": {},
   "outputs": [],
   "source": [
    "dfs[\"zero-shot\"] = load_zero_shot_preds(dataset, prompt, split)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8c1071f2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRPO-offline\n",
      "GRPO_no_std-offline\n",
      "RLOO-offline\n",
      "PPO-offline\n",
      "zero-shot\n"
     ]
    }
   ],
   "source": [
    "metrics = defaultdict(list)\n",
    "for k, df in dfs.items():\n",
    "    print(k)\n",
    "    metrics[\"algo\"].append(k)\n",
    "    metrics[\"ece\"].append(expected_calibration_error(df[\"hit\"].astype(float), df[\"answer_num\"] / 100))\n",
    "    metrics[\"auroc\"].append(roc_auc_score(df[\"hit\"].astype(float), df[\"answer_num\"] / 100))\n",
    "    metrics[\"accuracy_mle\"].append(accuracy_mle(df[\"hit\"].astype(bool), df[\"answer_num\"] / 100))\n",
    "metrics = pd.DataFrame(metrics)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cb133347",
   "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>algo</th>\n",
       "      <th>ece</th>\n",
       "      <th>auroc</th>\n",
       "      <th>accuracy_mle</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>GRPO-offline</td>\n",
       "      <td>0.292213</td>\n",
       "      <td>0.688252</td>\n",
       "      <td>0.669966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>GRPO_no_std-offline</td>\n",
       "      <td>0.035806</td>\n",
       "      <td>0.720972</td>\n",
       "      <td>0.675731</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>RLOO-offline</td>\n",
       "      <td>0.040251</td>\n",
       "      <td>0.721537</td>\n",
       "      <td>0.677635</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>PPO-offline</td>\n",
       "      <td>0.037518</td>\n",
       "      <td>0.718480</td>\n",
       "      <td>0.664943</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>zero-shot</td>\n",
       "      <td>0.174974</td>\n",
       "      <td>0.574141</td>\n",
       "      <td>0.555565</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                  algo       ece     auroc  accuracy_mle\n",
       "0         GRPO-offline  0.292213  0.688252      0.669966\n",
       "1  GRPO_no_std-offline  0.035806  0.720972      0.675731\n",
       "2         RLOO-offline  0.040251  0.721537      0.677635\n",
       "3          PPO-offline  0.037518  0.718480      0.664943\n",
       "4            zero-shot  0.174974  0.574141      0.555565"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b0feee43",
   "metadata": {},
   "outputs": [],
   "source": [
    "# print(metrics.to_latex(index=False, float_format=\"{:.2f}\".format))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b6714cb5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRPO-offline (5607, 11)\n",
      "GRPO_no_std-offline (5608, 11)\n",
      "RLOO-offline (5607, 11)\n",
      "PPO-offline (5608, 11)\n",
      "zero-shot (5597, 11)\n"
     ]
    }
   ],
   "source": [
    "for k, v in dfs.items():\n",
    "    print(k, v.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e7efdbea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRPO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "GRPO_no_std-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RLOO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PPO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "zero-shot\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k, df in dfs.items():\n",
    "    print(k)\n",
    "    plt.figure(figsize=(2.5, 1.5))\n",
    "    x = np.arange(10)\n",
    "    counts= df['answer_bin'].value_counts(normalize=True).to_dict()\n",
    "    y = [counts.get(x[i], 0) for i in range(len(x))]\n",
    "    plt.bar(x + 0.5, y, edgecolor=\"k\")\n",
    "    # _ = plt.xticks(ticks=x, labels=[f\"{i*10}-{(i+1)*10}%\" for i in range(10)], rotation=45, ha=\"right\")\n",
    "    # _ = plt.yticks(ticks=np.linspace(0, 0.5, 6), labels=[f\"{i*10}%\" for i in range(6)])\n",
    "    xticks = np.arange(11)\n",
    "    xlabels= [\"{:.1f}\".format(i/10) if i % 2 == 0 else \"\" for i in range(11)]\n",
    "    plt.xticks(ticks=xticks, labels=xlabels)\n",
    "    _ = plt.yticks(ticks=np.linspace(0, 0.5, 6))\n",
    "    for i in range(11):\n",
    "        plt.axvline(i, 0, 1, color=\"gray\", alpha=0.1)\n",
    "    plt.xlim(0, 10)\n",
    "    plt.gca().spines[[\"right\", \"top\"]].set_visible(False)\n",
    "    # plt.gca().set_box_aspect(1)\n",
    "    plt.ylim(0, 0.53)\n",
    "    plt.savefig(outdir / f\"pert_pred_dist_{k}.png\", transparent=True, dpi=200, bbox_inches=\"tight\")\n",
    "    plt.show(plt.gcf())\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b685d5df",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_info = defaultdict(list)\n",
    "for k, df in dfs.items():\n",
    "    for i in range(10):\n",
    "        curr = np.array(df[df[\"answer_bin\"] == i][\"hit\"].astype(float))\n",
    "        if len(curr) < 10:\n",
    "            continue\n",
    "        res = st.bootstrap((curr,), statistic=np.mean, confidence_level=0.95, n_resamples=10000, method=\"percentile\", random_state=0)\n",
    "        plot_info[\"model\"].append(k)\n",
    "        plot_info[\"bin\"].append(i)\n",
    "        plot_info[\"count\"].append(len(curr))\n",
    "        plot_info[\"freq\"].append(len(curr) / len(df))\n",
    "        plot_info[\"mean\"].append(curr.mean())\n",
    "        plot_info[\"ci_low\"].append(res.confidence_interval.low)\n",
    "        plot_info[\"ci_high\"].append(res.confidence_interval.high)\n",
    "\n",
    "plot_info = pd.DataFrame(plot_info)\n",
    "plot_info[\"ci_low_diff\"] = plot_info[\"mean\"] - plot_info[\"ci_low\"]\n",
    "plot_info[\"ci_high_diff\"] = plot_info[\"ci_high\"] - plot_info[\"mean\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27a68cc1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['0.0', '', '0.2', '', '0.4', '', '0.6', '', '0.8', '', '1.0']\n",
      "GRPO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['0.0', '', '0.2', '', '0.4', '', '0.6', '', '0.8', '', '1.0']\n",
      "GRPO_no_std-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['0.0', '', '0.2', '', '0.4', '', '0.6', '', '0.8', '', '1.0']\n",
      "RLOO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['0.0', '', '0.2', '', '0.4', '', '0.6', '', '0.8', '', '1.0']\n",
      "PPO-offline\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAPQAAADiCAYAAAB5oOp4AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjMsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvZiW1igAAAAlwSFlzAAAPYQAAD2EBqD+naQAAH/JJREFUeJzt3XtQHGW+N/Bv91y5DqS4BRYdo+aCJiESYTGy3ghYx0Rz9vgao0eyqOyq4U3M7CVhNyGLKUVXw5JoXMq4HLdqtULWd2M8kkqIuJjEEKlc2NWKkKMR2QW5HYEJQ5hb9/sHzsAwPTA90xNmen6fqlRlHp5+5iHhS/d0P/1rhud5HoQQWWBnewKEEOlQoAmREQo0ITJCgSZERijQhMgIBZoQGaFAEyIjFGhCZIQCTYiMUKAJkRHRgT5+/DhWr16N1NRUMAyD9957b8ZtmpqacMstt0Cj0eCGG27AW2+95cNUCSEzER1ok8mEpUuXYu/evV71//rrr3HffffhrrvuQmtrK5599lk8+eSTOHr0qOjJEkKmx/hzcwbDMDh48CDWrFnjsc+WLVtQX1+Pzz//3Nn28MMPY2hoCEeOHPH1rQkhAgL+Gbq5uRn5+fkubYWFhWhubva4jdlshtFodP4ZHh5Gf38/6MYwQqanDPQb9PT0IDk52aUtOTkZRqMRV65cQUREhNs2lZWVqKiocGsfGhqCTqfzeS48z2NkZAQAEB0dDYZhZDdWMM8tWMcKxNz+d+h/cb7nPGxKm99jWa9YEaeLw4+u/dGM/QMeaF+UlZXBYDA4XxuNRqSnp8/ijAgRh+M5XLFeQZQ6ClqV1udxeJ7HZfNljFpHveof8ECnpKSgt7fXpa23txexsbGCe2cA0Gg00Gg0gZ4aIQGnUWqgVfoXaIvSAgssXvUP+Gfo3NxcNDY2urQdO3YMubm5gX5rQsKO6ECPjIygtbUVra2tAMYvS7W2tqKzsxPA+OFyUVGRs/9TTz2FS5cu4Ve/+hXa2trw+uuv48CBA9i8ebM03wEhxEl0oM+cOYNly5Zh2bJlAACDwYBly5ahvLwcAPDtt986ww0A1113Herr63Hs2DEsXboUu3btwptvvonCwkKJvgVCiIPoz9B33nnntJePhFaB3XnnnTh//rzYtyKEiERruQmREQo0ITJCgSZERijQhMgIBZoQGaFAEyIjFGhCZIQCTYiMUKAJkREKNCEyQoEmREaCssABIbPFbDODtbJ+Vxm5YrsCK2eF2Wb2eyyzzQxG6d0YFGhCvme2mSUrGzRqGsW/hv8FpVYJK2/1aywrZ0WcKs6r/hRoQr4nZdkgmIEf6H6A29JvQ5Q6yq+xTCMm6GK9q6VHgSZkiunKBnE8D4uNh1rJgPWwF3eUDbJyVkSqIhGpivR5LjzPg1Nx0Ci9K8lFgSZEwKDJjkET53zdPWjDifYraO20wMYBShbIvEaNvAURSI2fiFF8FIu4yNk710yBJkRAw2ejONBi8vh1Gwec6bDgTIdr8b6HsqPwUE50oKfnEQWaEAEFiyNx6zwtugdtqG4YxnTPeGAY4NkCHVLjlYiPmt0rwXQdmhAB8VEKzEtSobXTjJnOdzMAWjvNmJekQnyU4mpMzyMKNCEecDyPkxfHwM3wBCaOB05eHAuKRzXRITchHlhsPKx27/pa7YDFBmhUwl/vM46h77JZ9BwSo9UQc46NAk2IB2olA5UCXoVapQDU06Tp7U87sbvxf0TPYePdN6AkN9Xr/hRoQjxgGQa3z9fi47bpD7tZBrh9vnba1WWP5lyDlRmuD20cs9rxYM34U1jffSoXWpX75+/EaDUAm9dzpkATMo1VmVH4uG3Mq37TSYrVIinWdbHKqGUiqBmpsYgU2MVPfiqmN+ikGCECBk12XOqzguOBh38YDYYZ3xNPxjLjl6we/mE0OB641GfFoMnLD90BQntoQgQILSyZetTtOAx/p3kE7zSP70VpYQkhQcixsGQqjudhs4+fBBP6zDzbC0so0IQIiI9S+LxIZDavR/v062Tv3r3Q6/XQarXIyclBS0vLtP2rq6uxYMECREREID09HZs3b8bY2MwnGggRo884hs+7hkX/6TPO/s8iN9PqFS+J3kPX1dXBYDCgpqYGOTk5qK6uRmFhIdrb25GUlOTW/5133sHWrVtRW1uL2267DRcvXsRPfvITMAyDqqoqSb4JQgDfr/VuuudGPJt/YwBm5NmFbiPeOP6V8/UtOz/E/Zlz8fiKechIjfV5XNGBrqqqQklJCYqLiwEANTU1qK+vR21tLbZu3erW/9SpU1ixYgUeeeQRAIBer8e6devw6aef+jxpQoT4eq03Kca7e42lcqi1C5vrWl0+g1vsHA6e78Zfz3Xh92sz8UBmmk9jiwq0xWLB2bNnUVZW5mxjWRb5+flobm4W3Oa2227Dn//8Z7S0tCA7OxuXLl3C4cOH8dhjj3l8H7PZDLN5Ypmc0WgUM00SRibXAIuOAKIjXNdejlomPlXqE1WIVAt9LuYwah2VvA6YkAvdRmyuax0/Qz7ls7b9+8PuzXWtuDEpxqc9tahADwwMwG63IznZ9bdgcnIy2traBLd55JFHMDAwgNtvvx08z8Nms+Gpp57Cr3/9a4/vU1lZiYqKCjFTI2HImxpgZutEaD7pPAmNynOVEanrgEWoIqBgXH+B1H5yaXyu05w4YxgG//XJ13j5/ywV/d4BP8vd1NSEF154Aa+//jpycnLw5ZdfYtOmTdi5cye2b98uuE1ZWRkMBoPztdFoRHp6eqCnSkKMNzXAVAwPYBgAEK2OgXaaQEtdB4xlWJfSQRzH4/3Wb517Yk/sHI9Df+/G7x5cIvq9RQU6ISEBCoUCvb29Lu29vb1ISUkR3Gb79u147LHH8OSTTwIAFi9eDJPJhJ/+9Kf4zW9+A5Z1P9Gu0Wig0VzdzzUkdE1XAwz8RBkhtUINrVL4UlQg6oBNNWazw2J3bxdisXEYs3LQqsRdiBLVW61WIysrC42Njc42juPQ2NiI3NxcwW1GR0fdQqtQjP+jBsP9o0S+OvqtqPlo2Pm6eF8/Xjs2hI5+3w+n/aFVKqBWeBc5tZIVHWbAh0Nug8GA9evXY/ny5cjOzkZ1dTVMJpPzrHdRURHS0tJQWVkJAFi9ejWqqqqwbNky5yH39u3bsXr1amewCZHaifYr2NMw7NJmswMft43h47YxbCzQIW9BxFWdE8syuD9zLg6e7572sFvBMnhgaSoYhhG90xMd6LVr16K/vx/l5eXo6elBZmYmjhw54jxR1tnZ6bJH3rZtGxiGwbZt29DV1YXExESsXr0azz//vNi3JsQrHf1W7GkYFrzl0dG2p2EY6XOU0Cd6qEgQII+vmIe/nuuatg/P8yhecZ1P4zN8CBz3Go1G6HQ6DA0NQafzruC4kMm3okVHR/t9aSIYxwrmuUk9Vv9gP07/6zTm6OYgQjWxt33t2JBX9zDfsVCL0pVxzvGMl40YsYzgnoX3+H1SbLrvc/J16Ml7agU7vkeefB3aMVZMTIxX7023TxJZCYU6YA9kpuGD/5uH+5fOdbapFSx+vGy83ddFJQDdnEFkRso6YIGUkRqL5/99MQ6e7wYAnC/PR5QEE6E9NJEVRx0wb8xUB+xq8vdjlgMFmsiKow7Y1Ooi7v1mrgMWiijQRHZmqu8ltl8ooUAT2dEnqrCxQAfWQx0wlgE2Fuiu+iWrqyFIPkEQIq28BRFIn6PEoXMmHG8fL2CgVAB587VYlRklyzADFGgiY/pEFX52d6wz0G+VJCJC8PZJ+aBDbhI25HYCTAjtoQm5CoSebTU26YL5hW6jxydn0LOtCAkyM9U7c5RJmoqebUWC3uSyQb7ied6rkkFjNn7S383jj7rwMJ6nskFSEKp35g16thUJat6UDfKGUMmg4VEew6Ou/SyTAv3Ft0aole7vqYsEYiPgsWyQFISebeUNsc+2okCTq2pq2aBBE4ehUe+qeEymi2AQqXQtGfTaR1/j9b91eNzmlQ94uD/QBnjmLj023KUXLBsUaijQZFY4ygYd/+Ky2zOkvPHQrZG49yaNS8mgn+Rej3+7+Qeix0qK0SBSpREsGxRqKNBkVgk9Q8ps47Dt3UEAwHP/EYcIgbO/cZEMwLn+IvD1sBaQTzksCjSZVVOfIdXRb8XRzyY+CD/33pDg6q7xggRXdaohgQJNgkYw1gELNbRSjASFyXXAplYbcbTtaRietYqdoYICTYLCB63enRjztl+4okCTWRcKdcBCBQWazDpf6oARYRRoMutCtQ5YMKJAk1kX7nXApESBJkEhnOuASYkCTYJCONcBkxJ9GiFBI1zrgEnJpz303r17odfrodVqkZOTg5aWlmn7Dw0NYcOGDZg7dy40Gg3mz5+Pw4cP+zRhIm+OOmAOb5UkonRlHIXZS6L30HV1dTAYDKipqUFOTg6qq6tRWFiI9vZ2JCUlufW3WCxYuXIlkpKS8O677yItLQ3ffPMN4uLipJg/CXGDJjsGTa53OZltE687BmzQKN3vgoqLZCDvcn++ER3oqqoqlJSUOJ8HXVNTg/r6etTW1mLr1q1u/Wtra/Hdd9/h1KlTUKnGf8vq9Xr/Zk1ko+Gz0Wlvn3TcdTXV+O2TgZpV6BIVaIvFgrNnz6KsrMzZxrIs8vPz0dwsXBPp/fffR25uLjZs2IBDhw4hMTERjzzyCLZs2eLxge9msxlm80Q5GKPRKGaaJAACVTboR4sUWHJttOixdBEMzDZaBjqVqEAPDAzAbrc7H+7ukJycjLa2NsFtLl26hI8++giPPvooDh8+jC+//BLPPPMMrFYrduzYIbhNZWUlKioqxEyNBFAgywYpVUCCD4/85nke1iuBKxkUqgJ+lpvjOCQlJeGNN96AQqFAVlYWurq68PLLL3sMdFlZGQwGg/O10WhEenp6oKdKPJhaNshXPM8DZteyQf6MJYeSQVITFeiEhAQoFAr09va6tPf29iIlJUVwm7lz50KlUrkcXi9atAg9PT2wWCxQq9Vu22g0Gmg09J8UbBxlg3zF8zwsSotL2SB/xpJDySCpibpspVarkZWVhcbGRmcbx3FobGxEbm6u4DYrVqzAl19+CY6b+Me/ePEi5s6dKxhmQojvRF+HNhgM2LdvH/70pz/hiy++wNNPPw2TyeQ8611UVORy0uzpp5/Gd999h02bNuHixYuor6/HCy+8gA0bNkj3XRBCAPjwGXrt2rXo7+9HeXk5enp6kJmZiSNHjjhPlHV2doJlJ35PpKen4+jRo9i8eTOWLFmCtLQ0bNq0CVu2bJHuuyCEAPDxpFhpaSlKS0sFv9bU1OTWlpubi9OnT/vyVoQQEejmDEJkhAJNiIxQoAmREQo0ITJCgSZERijQhMgIBZoQGaFAEyIjFGhCZIQCTYiMUNVPIppQHTBvUB2wwKNAy1igygYd/vsV/PWMeeaNp/hxlhorF9GDqQKJAi1Tk8sGGa8Aw6Pix9BFArERcCsblDOfx8IfuH5as9h4vPLB+FMhf7GKgVrp/kskNsIKK2ejskEBRIGWqcllgz69yPu2R12uwY9v1XpVNmjUYscrHxwHADy8LA+RavfAUtmgwKNAy5xGqcG/LVUj94aJz7zdgzY0tV3B+W8sAAAFCyy7Ro28BRFIjZ/4kYiPYqFVst6VDeInDqW1Ci0iVe6F8alsUOBRoMNAfJQC8VHje8wT7Vewp2HY5et2Djj3jQXnvrFgY4EOeQsinF/z5uHqF7qNeOP4V87Xt+z8EPdnzsXjK+YhIzV2mi2J1OiyVRjp6LdiT8MwOB7gpuTU0banYRgd/VavxzzU2oVVr57Af//jW2ebxc7h4PlurHr1BA61dkk1feIFCnQY+aDVu8L03va70G3E5rpWcDxgn/Ibws7x4Hhgc10rLnTTgxKuFgp0mOB4Hicvjrntmd37AScvjnl1qF37yaUZL4kxDIP/+uRrMVMlfqBAhwmLjYfV7l1fqx2wzHC5mON4vN/6rdueeSo7x+PQ37u9+gVB/EeBDhNqJQOVl5d+VQpAPcPp0jGbHRa7d2esLTYOY1Y6u301UKDDBMswuH2+FuwMi8ZYBrh9vnbGQ2mtUgG1wrsfH7WShVZFP2pXA/0rh5FVmd49S8qbfizL4P7MuVDM8BtCwTJ4YGmqX8tPifco0GFEn6jCxgIdWAZue2pH28YCHfSJ7otChDy+Yt6Mn415nkfxiut8nTIRiQIdBgZNdlzqs+JSnxVp8UpsKtAh85qJ54opWOAWvRqbCnRIi1c6+w6apj+LlpEai9+vzQTLwG1PrWAZsAzw+7WZtLjkKqKVYmGg4bNRHGjxfG3ZzgFnvrbgzNcWl/aHsqPwUM70D2N/IDMNNybFYN+Jr3DwfDcAQK1g8UBmKopXXEdhvsoo0GGgYHEkbp0n/jGw8VHeHcBlpMbi+X9f7Az0+fJ8RGm8O2wn0vLpkHvv3r3Q6/XQarXIyclBS0uLV9vt378fDMNgzZo1vrwt8VF8lALzklSi/zjWf4tFJ8Bmj+g9dF1dHQwGA2pqapCTk4Pq6moUFhaivb0dSUlJHrfr6OjAL37xC+Tl5fk1YTL7+oxj6Lvsejvm2KRVKxe6jdAKXPROjFYjks7aBJToQFdVVaGkpMT5POiamhrU19ejtrYWW7duFdzGbrfj0UcfRUVFBU6cOIGhoSG/Jk1m19ufdmJ34/94/PqDNc2C7RvvvgEluamBmhaByEBbLBacPXvW5YHuLMsiPz8fzc3C/4kA8NxzzyEpKQlPPPEETpw44ftsSVB4NOcarMxIFr1dYrQaAJUgCiRRgR4YGIDdbnc+3N0hOTkZbW1tgtucPHkSf/zjH9Ha2ur1+5jNZpjNE4d0RmN43K0jRQ0wQLgOmD9jmW2uh9dJsVokxYo/ycbzPEZGRnyeC5lZQM9yX758GY899hj27duHhIQEr7errKxERUVFAGcWfCbXAJMi0FPrgPkzlpWzUh2wECEq0AkJCVAoFOjt7XVp7+3tRUpKilv/r776Ch0dHVi9erWzjePGF+krlUq0t7fj+uuvd9uurKwMBoPB+dpoNCI9PV3MVEPO5BpgWpX4vd9kPM97VQfM27GoDljoEBVotVqNrKwsNDY2Oi89cRyHxsZGlJaWuvVfuHAhPvvsM5e2bdu24fLly9i9e7fHkGo0Gmg04fnDo1FqoFX6H2iv6oB5ORbVAQsdog+5DQYD1q9fj+XLlyM7OxvV1dUwmUzOs95FRUVIS0tDZWUltFotbr75Zpft4+LiAMCtXQ6ELucA48UFLDYOaiULVuBwOjFajamtvhazj49iEUfXhsKW6ECvXbsW/f39KC8vR09PDzIzM3HkyBHnibLOzk6wbHj+QM10OceTjXffgP9cHu/SNtNyTU+8Wa5J5IvhQ6CUhNFohE6nw9DQEHQ6nc/jTD7LGh0d7ffZ36ljTd5Df3yxH7sa2gG4FuRTMAAP4OcFC3DH/EQA3++h7Zdx+l+nMUc3BxGqCLc9tJjSu3GRLIyXjRixjOCehff4/Rk6kP9mwTBWMM/NMVZMTIxX/cNzVxogSbFa3JymA8sw2NXQLlhd0/59266GdrAMg5vTdIKXgCYv1+watGF3wzD+3jlx84Sj9O7uhmF0Ddr8Xq5J5IECHQBSFs8LROldIl8UaIlJXTxP6tK7RN4o0BKTsnheIErvEnmjQEtMyuJ5UpfeJfJHgZaYlMXzpC69S+SPAh0AUhXPk7r0LpE/CrSE+oxj+LxrGBzP4+cFCwSrayq+b/t5wQJwPI/Pu4bRZxzzOKaUpXeJ/NFBmoS8WSlm/37H/fLRdrx8dHzhidBKMQdH6V3HI2AnnyBz/LIQU3qXyBsFWkKebvx3rOXWKIXvdU6MVgP2yx7HzVsQgfQ5Shw6Z8Lx9vG9uVIB5M3XYlVmFIWZOFGgJeTPjf/9g66BFro5o2BxhDPQO9bEQatSgOOBS30Ti0ro5ozwRoEOUjPdnLH9/w0JttPNGeGNAu0nKcoGCZUM+tEiBZZcKz6YcZEsxmxjbmWDSHigQPtBqrJBQiWDlCogwccbyy5bqGxQuKJA+0GqskFSlgxyjEdlg8ITBVoC/pYNkrJkkGM8KhsUnuh0KCEyQoEmREYo0ITISNh/hvZUqXMmQpU6CZltYR9oKSt1EjLbwj7QQuuvx6x25xMUD/zsh4gUuNF4pvXXhMyGsA/01PXXF7qN+PPpb5yv//PNFtyfORePr5iHjNRYZ7vQ+mtCZhudFJvkUGsXVr16Av/9j2+dbRY7h4Pnu7Hq1RM41No1i7MjZGYU6O9d6DZic10rOB5uFTvtHA+OBzbXteJCd3g82paEJgr096SspU3IbKFAQ/pa2oTMFgo0pK2lTchs8inQe/fuhV6vh1arRU5ODlpaWjz23bdvH/Ly8hAfH4/4+Hjk5+dP2382SFlLm5DZJPons66uDgaDATt27MC5c+ewdOlSFBYWoq+vT7B/U1MT1q1bh7/97W9obm5Geno6CgoK0NUVPGeMpaylTchsEh3oqqoqlJSUoLi4GBkZGaipqUFkZCRqa2sF+7/99tt45plnkJmZiYULF+LNN98Ex3FobGz0e/JSkqqWNiGzSdTCEovFgrNnz6KsrMzZxrIs8vPz0dzc7NUYo6OjsFqtmDNnjsc+ZrMZZvPE+mqjUdpLRUJlg/SJSrz0YAa2vHsBDDP+uFYHBcuA53m89GAG9IlKjFpHBcsG+YrneSoZRCQhKtADAwOw2+1ITnZdKpmcnIy2tjavxtiyZQtSU1ORn5/vsU9lZSUqKirETM1r05UNitEBv17DouEfHFq+Gm9TssCt1/O452YWMbp2HP9mvJa2UNkgX/E8lQwi0riqSz9ffPFF7N+/H01NTdBqPVf4KCsrg8FgcL42Go1IT0+XZA5TywYNmjgMjU7sjrVK4N4lQMtXI+NzuT8KGtV48AeGJ8bRRTCIVEpTNohKBhGpiAp0QkICFAoFent7Xdp7e3uRkpIy7bavvPIKXnzxRXz44YdYsmTJtH01Gg00msD+YDvKBh3/4vK05XJ3vif8tYdujcS9N2kkKRtEJYOIVEQFWq1WIysrC42NjVizZg0AOE9wlZaWetzud7/7HZ5//nkcPXoUy5cv92vCUitYHIlb54mvBxYXyQAcPWSdBBfRh9wGgwHr16/H8uXLkZ2djerqaphMJhQXFwMAioqKkJaWhsrKSgDASy+9hPLycrzzzjvQ6/Xo6ekBAERHRyM6evYLwsdHKRAfJf5zK8/zMNLNViTIiA702rVr0d/fj/LycvT09CAzMxNHjhxxnijr7OwEy05cDfvDH/4Ai8WCBx980GWcHTt24Le//a1/syeEuPDppFhpaanHQ+ympiaX1x0dHb68BSHEB7SGkRAZoUATIiMUaEJkhAJNiIxQoAmREQo0ITIScmV8fX3SRVKMBokxtE6ayFvIBdrXJ11suudGPJt/YwBmREjwCLlAz/Ski3efyoVW5b6UM4n2ziQMhFygpz7pAgBGLTbn3zNSYwUfXQOAqnUS2aOTYoTISEjtoUeto1BZVQLt9kl/vwJ4qPpBZYOI3IVUoE/98xSihtwrg5itE4fSn3SedFYYmYrKBhG5C6lAqxgVYtQxAu08gPH6QNHqGGinCTTMVDaIyFdIBdpRNsgNP7kmmAZapfCpAZ7nYVFaqGwQkS06KUaIjMgu0BxdmiJhLOQD3dFvRc1HE/V1i/f147VjQ+jo9/2EFyGhKqQ+Q091ov0K9jQMu7TZ7MDHbWP4uG0MGwt0yFsQMUuzI+TqC9k9dEe/FXsahsHxwNTHOjva9jQM056ahJWQDfQHrd7VxPa2HyFyEJKB5ngeJy+Oue2Z3fsBJy+O0RpuEjZCMtAWG49Jqz2nZbUDk+7dIETWQjLQaiUDgTskBakUgIebrwiRnZAMNMswuH2+FuwM91awDHD7fK1fN2EQEkpCMtAAsCrTu3XY3vYjRA5CNtD6RBU2FujAMnDbUzvaNhbooE90v92SELkK6U+XeQsikD5HiUPnTDjePgYAUCqAvPlarMqMojCTsOPTHnrv3r3Q6/XQarXIyclBS0vLtP3/8pe/YOHChdBqtVi8eDEOHz7s02SF6BNV+Nndsc7Xb5UkonRlHIWZhCXRga6rq4PBYMCOHTtw7tw5LF26FIWFhejr6xPsf+rUKaxbtw5PPPEEzp8/jzVr1mDNmjX4/PPP/Z68EDoBRsKZ6EBXVVWhpKQExcXFyMjIQE1NDSIjI1FbWyvYf/fu3bj33nvxy1/+EosWLcLOnTtxyy234LXXXvN78oQQV6I+Q1ssFpw9exZlZWXONpZlkZ+fj+bmZsFtmpubYTAYXNoKCwvx3nvveXwfs9kMs3miXtfw8PgNGINDgxi+wmN41LWwgMUOcOZRAEDrV/1QC1yj1kWy0EUwGBkZgZWzwmg0wq72cnWKAJ7nMTIyAgDgOM7v+mRSjRXMcwvWsYJ5bo6xeJ5HTEzMjGOJCvTAwADsdjuSk13rYicnJ6OtrU1wm56eHsH+PT09Ht+nsrISFRUVbu3r8tbNOMfS6hm7EBKS+vr6kJiYOG2foDzLXVZW5rJXHxoawrXXXovOzk7odDq/xjYajUhPT8c///lPxMbGzrxBCI4VzHML1rGCeW6OsdRq9Yx9RQU6ISEBCoUCvb29Lu29vb1ISUkR3CYlJUVUfwDQaDTQaNwL7+l0Okn+4wAgNjZW9mNJPV44jCX1eFKO5c2hu6iTYmq1GllZWWhsbHS2cRyHxsZG5ObmCm6Tm5vr0h8Ajh075rE/IcR3og+5DQYD1q9fj+XLlyM7OxvV1dUwmUwoLi4GABQVFSEtLQ2VlZUAgE2bNuGOO+7Arl27cN9992H//v04c+YM3njjDWm/E0IIwPvg1Vdf5a+55hperVbz2dnZ/OnTp51fu+OOO/j169e79D9w4AA/f/58Xq1W8zfddBNfX18v6v3Gxsb4HTt28GNjY75MN+zGknq8cBhL6vFmayyG5+nuf0LkImRvziCEuKNAEyIjFGhCZIQCTYiMUKAJkREKNCEyQoEmREYo0ITICAWaEBmhQBMiIxRoQmTk/wMp1p9bQQJq4AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['0.0', '', '0.2', '', '0.4', '', '0.6', '', '0.8', '', '1.0']\n",
      "zero-shot\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x250 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for k in plot_info[\"model\"].unique():\n",
    "    plt.figure(figsize=(2.5, 2.5))\n",
    "    curr = plot_info[plot_info[\"model\"] == k]\n",
    "    curr = curr[curr[\"count\"] > 25]\n",
    "    plt.errorbar(curr[\"bin\"] + 0.5, curr[\"mean\"], yerr=curr[[\"ci_low_diff\", \"ci_high_diff\"]].to_numpy().T, capsize=5, fmt=\"o\", markersize=7)\n",
    "\n",
    "    for i in range(10):\n",
    "        plt.fill_between([i, i+1], [i/10, i/10], [(i+1)/10, (i+1)/10], color=\"green\", alpha=0.2, zorder=1)\n",
    "\n",
    "\n",
    "    xticks = np.arange(11)\n",
    "    xlabels= [\"{:.1f}\".format(i/10) if i % 2 == 0 else \"\" for i in xticks]\n",
    "    print(xlabels)\n",
    "    plt.xticks(ticks=xticks, labels=[])\n",
    "\n",
    "    plt.xlim(0, 10)\n",
    "    plt.ylim(0, 1)\n",
    "\n",
    "    _ = plt.yticks(ticks=np.linspace(0, 1, 6))\n",
    "\n",
    "    plt.gca().spines[[\"right\", \"top\"]].set_visible(False)\n",
    "    plt.gca().set_box_aspect(1)\n",
    "    for i in range(11):\n",
    "        plt.axvline(i, 0, 1, color=\"gray\", alpha=0.1)\n",
    "    print(k)\n",
    "    plt.savefig(outdir / f\"pert_calibration_binned_{k}.png\", transparent=True, dpi=200, bbox_inches=\"tight\")\n",
    "\n",
    "    plt.show(plt.gcf())\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e83338e0",
   "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>pert</th>\n",
       "      <th>hit_prob</th>\n",
       "      <th>pheno</th>\n",
       "      <th>pheno_markers</th>\n",
       "      <th>hit</th>\n",
       "      <th>prompt</th>\n",
       "      <th>thinking_content</th>\n",
       "      <th>answer</th>\n",
       "      <th>answer_num</th>\n",
       "      <th>answer_bin</th>\n",
       "      <th>answer_bin_val</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>SBNO1</td>\n",
       "      <td>0.037642</td>\n",
       "      <td>1</td>\n",
       "      <td>LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...</td>\n",
       "      <td>False</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>30</td>\n",
       "      <td>30.0</td>\n",
       "      <td>2</td>\n",
       "      <td>25.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>BRIP1</td>\n",
       "      <td>0.037643</td>\n",
       "      <td>1</td>\n",
       "      <td>LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...</td>\n",
       "      <td>False</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>30</td>\n",
       "      <td>30.0</td>\n",
       "      <td>2</td>\n",
       "      <td>25.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>RCOR1</td>\n",
       "      <td>0.037694</td>\n",
       "      <td>1</td>\n",
       "      <td>LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...</td>\n",
       "      <td>False</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>30</td>\n",
       "      <td>30.0</td>\n",
       "      <td>2</td>\n",
       "      <td>25.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>REXO2</td>\n",
       "      <td>0.037745</td>\n",
       "      <td>1</td>\n",
       "      <td>LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...</td>\n",
       "      <td>False</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>45</td>\n",
       "      <td>45.0</td>\n",
       "      <td>4</td>\n",
       "      <td>45.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>NCAPD3</td>\n",
       "      <td>0.037827</td>\n",
       "      <td>1</td>\n",
       "      <td>LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...</td>\n",
       "      <td>False</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>25</td>\n",
       "      <td>25.0</td>\n",
       "      <td>2</td>\n",
       "      <td>25.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>675</th>\n",
       "      <td>MAGOH</td>\n",
       "      <td>0.999806</td>\n",
       "      <td>50</td>\n",
       "      <td>HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...</td>\n",
       "      <td>True</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>85</td>\n",
       "      <td>85.0</td>\n",
       "      <td>8</td>\n",
       "      <td>85.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>676</th>\n",
       "      <td>USP8</td>\n",
       "      <td>0.999920</td>\n",
       "      <td>50</td>\n",
       "      <td>HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...</td>\n",
       "      <td>True</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>40</td>\n",
       "      <td>40.0</td>\n",
       "      <td>3</td>\n",
       "      <td>35.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>677</th>\n",
       "      <td>PSMD6</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>50</td>\n",
       "      <td>HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...</td>\n",
       "      <td>True</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>90</td>\n",
       "      <td>90.0</td>\n",
       "      <td>8</td>\n",
       "      <td>85.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>678</th>\n",
       "      <td>INTS8</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>50</td>\n",
       "      <td>HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...</td>\n",
       "      <td>True</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>75</td>\n",
       "      <td>75.0</td>\n",
       "      <td>7</td>\n",
       "      <td>75.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>679</th>\n",
       "      <td>INTS5</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>50</td>\n",
       "      <td>HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...</td>\n",
       "      <td>True</td>\n",
       "      <td>&lt;|im_start|&gt;user\\nI am planning a perturb-seq ...</td>\n",
       "      <td>\\nOkay, the user is planning a perturb-seq scr...</td>\n",
       "      <td>85</td>\n",
       "      <td>85.0</td>\n",
       "      <td>8</td>\n",
       "      <td>85.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5607 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "       pert  hit_prob  pheno  \\\n",
       "0     SBNO1  0.037642      1   \n",
       "1     BRIP1  0.037643      1   \n",
       "2     RCOR1  0.037694      1   \n",
       "3     REXO2  0.037745      1   \n",
       "4    NCAPD3  0.037827      1   \n",
       "..      ...       ...    ...   \n",
       "675   MAGOH  0.999806     50   \n",
       "676    USP8  0.999920     50   \n",
       "677   PSMD6  1.000000     50   \n",
       "678   INTS8  1.000000     50   \n",
       "679   INTS5  1.000000     50   \n",
       "\n",
       "                                         pheno_markers    hit  \\\n",
       "0    LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...  False   \n",
       "1    LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...  False   \n",
       "2    LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...  False   \n",
       "3    LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...  False   \n",
       "4    LRPPRC, HNRNPU, NCL, MT-ND4L, EIF4B, IPO5, EIF...  False   \n",
       "..                                                 ...    ...   \n",
       "675  HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...   True   \n",
       "676  HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...   True   \n",
       "677  HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...   True   \n",
       "678  HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...   True   \n",
       "679  HSPA1A, HSPA1B, DNAJB1, HSP90AA1, HSPH1, UBC, ...   True   \n",
       "\n",
       "                                                prompt  \\\n",
       "0    <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "1    <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "2    <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "3    <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "4    <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "..                                                 ...   \n",
       "675  <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "676  <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "677  <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "678  <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "679  <|im_start|>user\\nI am planning a perturb-seq ...   \n",
       "\n",
       "                                      thinking_content answer  answer_num  \\\n",
       "0    \\nOkay, the user is planning a perturb-seq scr...     30        30.0   \n",
       "1    \\nOkay, the user is planning a perturb-seq scr...     30        30.0   \n",
       "2    \\nOkay, the user is planning a perturb-seq scr...     30        30.0   \n",
       "3    \\nOkay, the user is planning a perturb-seq scr...     45        45.0   \n",
       "4    \\nOkay, the user is planning a perturb-seq scr...     25        25.0   \n",
       "..                                                 ...    ...         ...   \n",
       "675  \\nOkay, the user is planning a perturb-seq scr...     85        85.0   \n",
       "676  \\nOkay, the user is planning a perturb-seq scr...     40        40.0   \n",
       "677  \\nOkay, the user is planning a perturb-seq scr...     90        90.0   \n",
       "678  \\nOkay, the user is planning a perturb-seq scr...     75        75.0   \n",
       "679  \\nOkay, the user is planning a perturb-seq scr...     85        85.0   \n",
       "\n",
       "     answer_bin  answer_bin_val  \n",
       "0             2            25.0  \n",
       "1             2            25.0  \n",
       "2             2            25.0  \n",
       "3             4            45.0  \n",
       "4             2            25.0  \n",
       "..          ...             ...  \n",
       "675           8            85.0  \n",
       "676           3            35.0  \n",
       "677           8            85.0  \n",
       "678           7            75.0  \n",
       "679           8            85.0  \n",
       "\n",
       "[5607 rows x 11 columns]"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfs[\"RLOO-offline\"]"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "uncalibrated-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.12.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
