{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6fdfc388",
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import pickle\n",
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "\n",
    "import os\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import glob\n",
    "import numpy as np\n",
    "from IPython.display import clear_output\n",
    "from collections import Counter\n",
    "os.chdir(\"../\")\n",
    "\n",
    "from src import utils\n",
    "from src.utils import optimal_tokenization\n",
    "from matplotlib.lines import Line2D\n",
    "from matplotlib.patches import Patch\n",
    "from matplotlib.ticker import LogLocator\n",
    "\n",
    "\n",
    "t_val = 2.132 # t-value for 90% confidence interval and 5 d.o.f\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "325463c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Custom class for log locator to filter ticks\n",
    "class CustomLogLocator(LogLocator):\n",
    "    def __init__(self, base=10.0, subs=None, numticks=10, threshold=0.2):\n",
    "        super().__init__(base=base, subs=subs, numticks=numticks)\n",
    "        self.threshold = threshold\n",
    "\n",
    "    def tick_values(self, vmin, vmax):\n",
    "        ticks = super().tick_values(vmin, vmax)\n",
    "        # Filter ticks greater than the threshold\n",
    "        return [tick for tick in ticks if tick > self.threshold]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "608b7f68",
   "metadata": {},
   "source": [
    "# Plot the probability that the split token sequence is plausible"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9c8c6517",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 389.373x240.646 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Load pickle\n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.9_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_09 = pickle.load(f)\n",
    "\n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.95_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_095 = pickle.load(f)\n",
    "    \n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.99_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_099 = pickle.load(f)\n",
    "\n",
    "#Define the splits used to generated the data, i.e. the number of iterations in the heuristic\n",
    "splits = [1,5,10, 15, 20 ,25 ,30 ,35, 40 ,45 ,50, 60,70,80,90,100, 110,  120, 130,  140,  150,  160,  170, 180 ,190, 200]\n",
    "\n",
    "percentage_09 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "percentage_095 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "percentage_099 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "\n",
    "\n",
    "#Compute the percentage of plausible sequences for each top-p value, and for each realization of the sequences, indexed by \"seq_idx\" \n",
    "\n",
    "for seq_idx in range(len((data_099[\"top_p_count\"]))):\n",
    "    percentage_09.append( np.array( [ data_09[\"top_p_count\"][seq_idx][i]  * splits[i]/ sum(data_09[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "    percentage_095.append( np.array( [ data_095[\"top_p_count\"][seq_idx][i]  * splits[i]/ sum(data_095[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "    percentage_099.append( np.array( [ data_099[\"top_p_count\"][seq_idx][i]  * splits[i] / sum(data_099[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "mean_09 = np.mean( np.stack(percentage_09,axis=0) , axis=0)\n",
    "std_09 = np.std( np.stack(percentage_09,axis=0) , axis=0)\n",
    "\n",
    "mean_095 = np.mean( np.stack(percentage_095,axis=0) , axis=0)\n",
    "std_095 = np.std( np.stack(percentage_095,axis=0) , axis=0)\n",
    "\n",
    "mean_099 = np.mean( np.stack(percentage_099,axis=0) , axis=0)\n",
    "std_099 = np.std( np.stack(percentage_099,axis=0) , axis=0)\n",
    "\n",
    "\n",
    "\n",
    "splits_new = np.array(splits)\n",
    "mean_09_new = np.array(mean_09)\n",
    "mean_095_new = np.array(mean_095)\n",
    "mean_099_new = np.array(mean_099)\n",
    "std_09_new = np.array(std_09)\n",
    "std_095_new = np.array(std_095)\n",
    "std_099_new = np.array(std_099)\n",
    "\n",
    "\n",
    "df = pd.DataFrame({\n",
    "    'mean_percent':np.concatenate( (mean_09, mean_095, mean_099) ),\n",
    "    'top-p': ['085'] * len(mean_09) + ['09'] * len(mean_095) + ['095'] * len(mean_099),\n",
    "    'splits' : np.concatenate( (splits, splits, splits) ), \n",
    "})\n",
    "\n",
    "\n",
    "sns.set_theme(context='paper', style='ticks', font_scale=1)\n",
    "width_pt = 469\n",
    "palette = sns.color_palette('husl', 3)\n",
    "\n",
    "utils.latexify() # Computer Modern, with TeX\n",
    "\n",
    "fig_width, fig_height = utils.get_fig_dim(width_pt, fraction=0.6)\n",
    "fig, ax = plt.subplots(figsize=(fig_width, fig_height))\n",
    "\n",
    "\n",
    "sns.lineplot(data=df, x=\"splits\", y='mean_percent', hue='top-p', palette=palette, ax=ax, linewidth=0.5, markersize=4,marker=\"o\", err_style= \"band\", linestyle=\"-\", markeredgewidth=0)\n",
    "\n",
    "\n",
    "ax.fill_between(splits, mean_09-std_09 * t_val, mean_09+std_09 * t_val, color=palette[0], alpha=0.2)\n",
    "\n",
    "ax.fill_between(splits, mean_095-std_095 * t_val, mean_095+std_095 * t_val, color=palette[1], alpha=0.2)\n",
    "\n",
    "ax.fill_between(splits, mean_099-std_099 * t_val, mean_099+std_099 * t_val, color=palette[2], alpha=0.2)\n",
    "\n",
    "\n",
    "sns.despine(ax=ax)\n",
    "ax.set_xlabel(r\"Number of iterations, $m$\")\n",
    "ax.set_ylabel(r\"Plausible sequences (\\%)\")\n",
    "\n",
    "plt.legend().set_visible(False)\n",
    "\n",
    "ax.set_xlim(0,200)\n",
    "\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f22dc86d",
   "metadata": {},
   "source": [
    "# Plot the total overcharge %"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e11dfa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 389.373x240.646 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "70 15.913906482390217\n",
      "40 5.632332653621815\n",
      "25 2.2595836747161315\n"
     ]
    }
   ],
   "source": [
    "\n",
    "#Load the LMSYS-generated data using the src/heuristic_misreporting.py script\n",
    "#Load the pkl or json files. Since pkl files save the generated tensors, their size is >100MB and we do not include them in this code. We include the json files instead, which are smaller but contain the same generated data.\n",
    "\n",
    "#Load pickle\n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.9_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_09 = pickle.load(f)\n",
    "\n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.95_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_095 = pickle.load(f)\n",
    "    \n",
    "with open(\"outputs/heuristic/L1B/heuristic_model_Llama-3.2-1B-Instruct_T_1.45_p_0.99_k_None_prompt_idare you .pkl\", \"rb\") as f:\n",
    "    data_099 = pickle.load(f)\n",
    "\n",
    "\n",
    "#Define the splits used to generated the data\n",
    "splits = [1, 5, 10, 15, 20 ,25 ,30 ,35, 40 ,45 ,50, 60, 70, 80, 90, 100, 110,  120, 130,  140,  150,  160, 170, 180 ,190, 200]\n",
    "\n",
    "\n",
    "percentage_09 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "percentage_095 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "percentage_099 = [ [] for i in range(len((data_099[\"top_p_count\"]))) ]\n",
    "\n",
    "\n",
    "#Compute the percentage of plausible sequences for each top-p value, and for each realization of the sequences, indexed by \"seq_idx\" \n",
    "for seq_idx in range(len((data_099[\"top_p_count\"]))):\n",
    "    percentage_09.append( np.array( [ data_09[\"top_p_count\"][seq_idx][i]  * splits[i]/ sum(data_09[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "    percentage_095.append( np.array( [ data_095[\"top_p_count\"][seq_idx][i]  * splits[i]/ sum(data_095[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "    percentage_099.append( np.array( [ data_099[\"top_p_count\"][seq_idx][i]  * splits[i] / sum(data_099[\"generated_outputs\"][seq_idx]) * 100  for i in range( len(splits))] ) )\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "mean_09 = np.mean( np.stack(percentage_09,axis=0) , axis=0)\n",
    "std_09 = np.std( np.stack(percentage_09,axis=0) , axis=0)\n",
    "\n",
    "mean_095 = np.mean( np.stack(percentage_095,axis=0) , axis=0)\n",
    "std_095 = np.std( np.stack(percentage_095,axis=0) , axis=0)\n",
    "\n",
    "mean_099 = np.mean( np.stack(percentage_099,axis=0) , axis=0)\n",
    "std_099 = np.std( np.stack(percentage_099,axis=0) , axis=0)\n",
    "\n",
    "\n",
    "splits = np.array(splits)\n",
    "mean_09 = np.array(mean_09)\n",
    "mean_095 = np.array(mean_095)\n",
    "mean_099 = np.array(mean_099)\n",
    "std_09 = np.array(std_09)\n",
    "std_095 = np.array(std_095)\n",
    "std_099 = np.array(std_099)\n",
    "\n",
    "\n",
    "df = pd.DataFrame({\n",
    "    'mean_percent':np.concatenate( (mean_09, mean_095, mean_099) ),\n",
    "    'top-p': ['085'] * len(mean_09) + ['09'] * len(mean_095) + ['095'] * len(mean_099),\n",
    "    'splits' : np.concatenate( (splits, splits, splits) ), \n",
    "})\n",
    "\n",
    "\n",
    "sns.set_theme(context='paper', style='ticks', font_scale=1)\n",
    "width_pt = 469\n",
    "palette = sns.color_palette('husl', 3)\n",
    "\n",
    "utils.latexify() # Computer Modern, with TeX\n",
    "\n",
    "\n",
    "\n",
    "fig_width, fig_height = utils.get_fig_dim(width_pt, fraction=0.6)\n",
    "fig, ax = plt.subplots(figsize=(fig_width, fig_height))\n",
    "\n",
    "\n",
    "sns.lineplot(data=df, x=\"splits\", y='mean_percent', hue='top-p', palette=palette, ax=ax, linewidth=0.5, markersize=4,marker=\"o\", err_style= \"band\", linestyle=\"-\", markeredgewidth=0)\n",
    "\n",
    "\n",
    "ax.fill_between(splits, mean_09-std_09 * t_val, mean_09+std_09 * t_val, color=palette[0], alpha=0.2)\n",
    "\n",
    "ax.fill_between(splits, mean_095-std_095 * t_val, mean_095+std_095 * t_val, color=palette[1], alpha=0.2)\n",
    "\n",
    "ax.fill_between(splits, mean_099-std_099 * t_val, mean_099+std_099 * t_val, color=palette[2], alpha=0.2)\n",
    "\n",
    "\n",
    "\n",
    "#Plot the maximum of each curve\n",
    "x_max_099 = splits[np.argmax(mean_099) ]      # x-coordinate at the maximum\n",
    "y_max_099 = mean_099[ np.argmax(mean_099)]      # Maximum y value\n",
    "\n",
    "x_max_09 = splits[np.argmax(mean_09) ]      # x-coordinate at the maximum\n",
    "y_max_09 = mean_09[ np.argmax(mean_09)]      # Maximum y value\n",
    "\n",
    "\n",
    "x_max_095 = splits[np.argmax(mean_095) ]      # x-coordinate at the maximum\n",
    "y_max_095 = mean_095[ np.argmax(mean_095)]      # Maximum y value\n",
    "\n",
    "\n",
    "\n",
    "ax.plot( [ -2, x_max_099], [y_max_099, y_max_099] , color=palette[2], linestyle='--',linewidth=0.7)\n",
    "ax.plot([x_max_099, x_max_099], [-2, y_max_099], color=palette[2], linestyle='--', linewidth=0.7)\n",
    "\n",
    "ax.plot( [ -2, x_max_09], [y_max_09, y_max_09] , color=palette[0], linestyle='--',linewidth=0.7)\n",
    "ax.plot([x_max_09, x_max_09], [-2, y_max_09], color=palette[0], linestyle='--', linewidth=0.7)\n",
    "\n",
    "ax.plot( [ -2, x_max_095], [y_max_095, y_max_095] , color=palette[1], linestyle='--',linewidth=0.7)\n",
    "ax.plot([x_max_095, x_max_095], [-2, y_max_095], color=palette[1], linestyle='--', linewidth=0.7)\n",
    "\n",
    "\n",
    "sns.despine(ax=ax)\n",
    "ax.set_xlabel(r\"Number of iterations, $m$\")\n",
    "ax.set_ylabel(r\"Overcharged tokens (\\%)\")\n",
    "\n",
    "plt.legend().set_visible(False)\n",
    "\n",
    "ax.set_yscale(\"symlog\", linthresh=1)\n",
    "\n",
    "ax.set_ylim(-0.1,16)\n",
    "ax.set_xlim(0,200)\n",
    "\n",
    "\n",
    "ax.yaxis.set_major_locator(LogLocator(base=10.0, subs=None, numticks=10))  # Major ticks\n",
    "ax.yaxis.set_minor_locator(CustomLogLocator(base=10.0, subs=[2, 3, 4, 5, 6, 7, 8, 9], numticks=10, threshold=0.2))  # Custom minor ticks\n",
    "\n",
    "\n",
    "ax.set_yticks([1,10], [1,10] )\n",
    "\n",
    "fig.tight_layout()\n",
    "plt.show()\n",
    "print(x_max_099, y_max_099)\n",
    "print(x_max_095, y_max_095)\n",
    "print(x_max_09, y_max_09)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env",
   "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
