{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "source": [
    "import numpy as np\n",
    "from datasets import load_dataset\n",
    "from transformers import AutoTokenizer, AutoModelForSequenceClassification\n",
    "import numpy as np\n",
    "ds = load_dataset(\"CARROT-LLM-Routing/SPROUT-o3mini\")\n",
    "ds_test = load_dataset(\"CARROT-LLM-Routing/SPROUT-o3mini\", split = 'test')\n",
    "ds_train = load_dataset(\"CARROT-LLM-Routing/SPROUT-o3mini\", split = 'train')\n",
    "#arena = load_dataset(\"allysson-oliveira/fms-dataset\", token=\"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\", split = 'ood_arena')\n",
    "COSTS = {'openai-o3-mini': [1.1, 4.40], 'aws-claude-3-5-sonnet-v1': [3, 15], 'aws-titan-text-premier-v1': [0.5, 1.5],\n",
    "            'openai-gpt-4o': [2.5, 10], 'openai-gpt-4o-mini': [0.15, 0.6],\n",
    "            'wxai-granite-3-2b-instruct-8k-max-tokens': [0.1, 0.1],\n",
    "            'wxai-granite-3-8b-instruct-8k-max-tokens': [0.2, 0.2],\n",
    "            'wxai-llama-3-1-70b-instruct': [0.9, 0.9], 'wxai-llama-3-1-8b-instruct': [0.2, 0.2],\n",
    "            'wxai-llama-3-2-1b-instruct': [0.06, 0.06], 'wxai-llama-3-2-3b-instruct': [0.06, 0.06],\n",
    "            'wxai-llama-3-3-70b-instruct': [0.9, 0.9], 'wxai-mixtral-8x7b-instruct-v01': [0.6, 0.6],\n",
    "            'wxai-llama-3-405b-instruct': [3.5, 3.5]\n",
    "        }\n",
    "## CORRECTLY FORMAT DATA\n",
    "all_models = ds_test.to_pandas().columns.tolist()[6:]\n",
    "print(COSTS.keys())\n",
    "print(all_models)\n",
    "test_inputs = ds_test['prompt']\n",
    "EXP = 'cost'\n",
    "def get_labels(split, models, mode):\n",
    "    labels = []\n",
    "    labelsin = []\n",
    "    if mode == 'cost':\n",
    "        for m in models:\n",
    "            labels.append([sample['num_output_tokens']*COSTS[m][0]/1000000 for sample in split[m]])\n",
    "            labelsin.append([sample['num_output_tokens']*COSTS[m][1]/1000000 for sample in split[m]])\n",
    "        return np.array(labels).T, np.array(labelsin).T\n",
    "    else:\n",
    "        for m in models:\n",
    "            labels.append([sample['score'] for sample in split[m]])\n",
    "        return np.array(labels).T\n",
    "if EXP == 'cost':\n",
    "    train_labels = get_labels(ds_train, all_models, 'cost')\n",
    "cost_mean_output, cost_mean_input = np.mean(train_labels[0], axis=0), np.mean(train_labels[1], axis=0)\n",
    "avg_costs = cost_mean_output+cost_mean_input"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "dict_keys(['openai-o3-mini', 'aws-claude-3-5-sonnet-v1', 'aws-titan-text-premier-v1', 'openai-gpt-4o', 'openai-gpt-4o-mini', 'wxai-granite-3-2b-instruct-8k-max-tokens', 'wxai-granite-3-8b-instruct-8k-max-tokens', 'wxai-llama-3-1-70b-instruct', 'wxai-llama-3-1-8b-instruct', 'wxai-llama-3-2-1b-instruct', 'wxai-llama-3-2-3b-instruct', 'wxai-llama-3-3-70b-instruct', 'wxai-mixtral-8x7b-instruct-v01', 'wxai-llama-3-405b-instruct'])\n",
      "['openai-o3-mini', 'wxai-llama-3-405b-instruct', 'wxai-llama-3-3-70b-instruct', 'wxai-llama-3-2-3b-instruct', 'wxai-llama-3-2-1b-instruct', 'wxai-llama-3-1-8b-instruct', 'wxai-llama-3-1-70b-instruct', 'aws-titan-text-premier-v1', 'wxai-mixtral-8x7b-instruct-v01', 'aws-claude-3-5-sonnet-v1', 'openai-gpt-4o-mini', 'openai-gpt-4o', 'wxai-granite-3-8b-instruct-8k-max-tokens', 'wxai-granite-3-2b-instruct-8k-max-tokens']\n"
     ]
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "#from transformers import AutoTokenizer, AutoModelForSequenceClassification\n",
    "#import numpy as np\n",
    "import torch\n",
    "from tqdm import tqdm\n",
    "bench = ''\n",
    "hf_tok = \"\"\n",
    "carr_tok = \"\"\n",
    "\n",
    "input_counter = AutoTokenizer.from_pretrained(\"meta-llama/Llama-3.1-70B\", token=hf_tok)\n",
    "tokenizer = AutoTokenizer.from_pretrained('roberta-base')\n",
    "\n",
    "score_predictor = AutoModelForSequenceClassification.from_pretrained(\n",
    "    'CARROT-LLM-Routing/Perfo3',\n",
    "    problem_type=\"multi_label_classification\",\n",
    "    num_labels=len(COSTS), token = carr_tok\n",
    ")\n",
    "\n",
    "\n",
    "# Example queries\n",
    "prompts = ds_test['prompt']\n",
    "#prompts = [e['prompt'] for i, e in enumerate(arena) if bench in e['dataset']]\n",
    "#prompts = ds['test']['prompt'][MMLUids]\n",
    "#prompts = arena['prompt']\n",
    "scores = []\n",
    "input_tokens = []\n",
    "output_tokens = []\n",
    "costs = []\n",
    "for idx, m in enumerate(all_models):\n",
    "    scores_m = []\n",
    "    input_tokens_m = []\n",
    "    output_tokens_m = []\n",
    "    for entry in ds_test:\n",
    "    #for entry in arena:\n",
    "        if bench in entry['dataset']:\n",
    "            scores_m.append(entry[m][\"score\"])\n",
    "            input_tokens_m.append(entry[m][\"num_input_tokens\"])\n",
    "            output_tokens_m.append(entry[m][\"num_output_tokens\"])\n",
    "    scores.append(scores_m)\n",
    "    input_tokens.append(input_tokens_m)\n",
    "    output_tokens.append(output_tokens_m) \n",
    "input_tokens = np.array(input_tokens).T\n",
    "output_tokens = np.array(output_tokens).T\n",
    "for i, model in enumerate(all_models):\n",
    "            cost = (input_tokens[:, i] * COSTS[model][0] / 1000000) \\\n",
    "                        + (output_tokens[:, i] * COSTS[model][1] / 1000000)\n",
    "            costs.append(cost.tolist())\n",
    "scores = np.array(scores).T\n",
    "costs = np.array(costs).T\n",
    "input_counter.pad_token = tokenizer.eos_token\n",
    "\n",
    "print('predicting score')\n",
    "\n",
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "\n",
    "score_predictor = score_predictor.to(device)\n",
    "\n",
    "batch_size = 1  # Adjust based on memory limits\n",
    "p_scores = []\n",
    "p_logits = []\n",
    "for i, prompt in tqdm(enumerate(prompts), total = len(prompts)):\n",
    "    tokenized_text = tokenizer(\n",
    "           prompt,\n",
    "            truncation=True,\n",
    "            is_split_into_words=False,\n",
    "            return_tensors='pt'\n",
    "       )\n",
    "    tokenized_text.to(device)\n",
    "    with torch.no_grad():\n",
    "        p_scores.append(1 / (1 + np.exp(-score_predictor(tokenized_text['input_ids']).logits.cpu().numpy())))\n",
    "        p_logits.append(score_predictor(tokenized_text['input_ids']).logits.cpu().numpy())\n",
    "        #p_output_tokens.append(output_counter(batch).logits.cpu().numpy())\n",
    "\n",
    "#p_scores = 1 / (1 + np.exp(-score_predictor.predict(tokenized_text[\"input_ids\"]).logits.cpu().detach().numpy()))\n",
    "del score_predictor\n",
    "\n",
    "torch.cuda.empty_cache()\n",
    "\n",
    "import gc\n",
    "gc.collect()\n",
    "\n",
    "print('predicting cost')\n",
    "output_counter = AutoModelForSequenceClassification.from_pretrained(\n",
    "    'CARROT-LLM-Routing/costo3',\n",
    "    problem_type=\"regression\",\n",
    "    num_labels=len(COSTS), token = carr_tok\n",
    ")\n",
    "p_output_tokens = []\n",
    "output_counter = output_counter.to(device)\n",
    "for i, prompt in tqdm(enumerate(prompts), total = len(prompts)):\n",
    "    tokenized_text = tokenizer(\n",
    "           prompt,\n",
    "            truncation=True,\n",
    "            is_split_into_words=False,\n",
    "            return_tensors='pt'\n",
    "       )\n",
    "    tokenized_text.to(device)\n",
    "    with torch.no_grad():\n",
    "        #p_scores.append(1 / (1 + np.exp(-score_predictor(tokenized_text).logits.cpu().numpy())))\n",
    "        p_output_tokens.append(output_counter(tokenized_text['input_ids']).logits.cpu().numpy())\n",
    "print('counting inputs')\n",
    "    #print(model_idx.shape)"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "predicting score\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|███████████████████████████████████████| 6494/6494 [01:31<00:00, 71.28it/s]\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "predicting cost\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "100%|██████████████████████████████████████| 6494/6494 [00:48<00:00, 134.96it/s]"
     ]
    },
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "counting inputs\n"
     ]
    },
    {
     "output_type": "stream",
     "name": "stderr",
     "text": [
      "\n"
     ]
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "source": [
    "cost_mean_output, cost_mean_input = np.mean(train_labels[0], axis=0), np.mean(train_labels[1], axis=0)\n",
    "avg_costs = cost_mean_output+cost_mean_input\n",
    "api_costs = np.array([COSTS[k][1]/1000000 for k in COSTS.keys()])"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "source": [
    "print('counting inputs')\n",
    "p_scores = np.concatenate(p_scores, axis = 0)\n",
    "p_logits = np.concatenate(p_logits, axis=0)\n",
    "p_output_tokens = np.concatenate(p_output_tokens, axis = 0)\n",
    "p_input_tokens = [input_counter(prompt, return_tensors=\"pt\")[\"input_ids\"].shape[1] for prompt in prompts]\n",
    "p_input_tokens = np.array(p_input_tokens).T\n",
    "\n",
    "p_costs = []\n",
    "for i, model in enumerate(all_models):\n",
    "    p_cost = (p_input_tokens * COSTS[model][0] / 1000000) + (p_output_tokens[:, i] * COSTS[model][1] / 1000)\n",
    "    p_costs.append(p_cost.tolist())\n",
    "p_costs = np.array(p_costs).T\n",
    "lamb_range = np.arange(0, 1.001, 0.01)\n",
    "router_cost = np.zeros(shape = (scores.shape[0], lamb_range.shape[0]))\n",
    "base_cost = np.zeros(shape = (scores.shape[0], lamb_range.shape[0]))\n",
    "router_perf = np.zeros_like(router_cost)\n",
    "base_perf = np.zeros_like(router_cost)\n",
    "for idx_lam, lam in enumerate(lamb_range):\n",
    "    model_idx = ((1 - lam) * p_scores - lam * p_costs * 100).argmax(axis=1, keepdims=True)\n",
    "    rbench_idx = ((1 - lam) * p_scores - lam * avg_costs * 100).argmax(axis=1, keepdims=True)\n",
    "    router_perf[:, idx_lam] = np.take_along_axis(scores, model_idx, axis = 1).reshape((-1))\n",
    "    router_cost[:, idx_lam] = np.take_along_axis(costs, model_idx, axis = 1).reshape((-1))\n",
    "    base_perf[:, idx_lam] = np.take_along_axis(scores, rbench_idx, axis = 1).reshape((-1))\n",
    "    base_cost[:, idx_lam] = np.take_along_axis(costs, rbench_idx, axis = 1).reshape((-1))\n",
    "    #print(model_idx.shape)"
   ],
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "counting inputs\n"
     ]
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "source": [
    "import matplotlib.pyplot as plt\n",
    "fig, ax = plt.subplots(1, 1, figsize = (4.3, 4.3))\n",
    "markers = ['o', 's', 'D', '^', 'v', 'p', '*', 'x', '+', 'h', 'H', 'd', '>', 'P']\n",
    "zerorouters = [12, 10, 0]\n",
    "ax.errorbar(router_cost.mean(axis = 0), router_perf.mean(axis = 0),\n",
    "        linestyle='--', linewidth=1, alpha = 1, c = 'orange', label = 'CARROT')\n",
    "ax.errorbar(base_cost.mean(axis = 0), base_perf.mean(axis = 0),\n",
    "        linestyle='--', linewidth=1, alpha = 1, c = 'blue', label = 'Routerbench')\n",
    "cost_mean = costs.mean(axis = 0)\n",
    "scores_mean = scores.mean(axis = 0)\n",
    "ax.errorbar(cost_mean[zerorouters], scores_mean[zerorouters],\n",
    "        linestyle='--', linewidth=1, alpha = 1, c = 'grey', label = 'zero router')\n",
    "for i, txt in enumerate(all_models):\n",
    "    x, y = cost_mean[i], scores_mean[i]\n",
    "    ax.scatter([x], [y], marker = markers[i])\n",
    "    ax.annotate(all_models[i], (x, y), size=5.5)\n",
    "    #ax.annotate(l, (x, y))\n",
    "ax.set_xlabel('Cost Per Query, \\$')\n",
    "ax.set_ylabel('Accuracy')\n",
    "#ax.set_xlim(0, 0.005)\n",
    "ax.set_ylim(0.60, 0.95)\n",
    "# ax.plot(cost_router.mean(axis = 0), correctness_router.mean(axis = 0), linestyle='-', linewidth=2, label='router', alpha = 0.3)\n",
    "ax.legend(loc = 'lower right')\n",
    "ax.grid(True)\n",
    "ax.grid(True)\n",
    "#plt.savefig('SPROUTneurips.pdf', bbox_inches = 'tight', dpi = 400, transparent=False)"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 430x430 with 1 Axes>"
      ]
     },
     "metadata": {}
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "def AUC(cost, perf):\n",
    "    AUC = np.trapz(perf, cost)/(np.max(cost)-np.min(cost))\n",
    "    return -AUC\n",
    "print('CARROT:' +str(AUC(router_cost.mean(axis = 0), router_perf.mean(axis = 0))))\n",
    "print('Routerbench:' + str(AUC(base_cost.mean(axis = 0), base_perf.mean(axis = 0))))\n",
    "print('Zero Router:' + str(AUC(cost_mean[zerorouters], scores_mean[zerorouters])))\n"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "benchmarks = {'ragbench': ([], []), 'gpqa': ([], []), 'MuSR': ([], []), 'MMLU-Pro': ([], []), 'MATH': ([], []), 'openhermes': ([], [])}\n",
    "for idx, entry in enumerate(tqdm(ds['test']['prompt'])):\n",
    "    for bmrk in benchmarks.keys():\n",
    "        if bmrk in ds['test']['dataset'][idx]:\n",
    "            benchmarks[bmrk][0].append(np.mean(np.abs(p_costs[idx]-costs[idx])))\n",
    "            p_corr = np.where(p_scores[idx] < 0.5, 0, 1)\n",
    "            corr = np.where(scores[idx] < 0.5, 0, 1)\n",
    "            benchmarks[bmrk][1].append(np.mean([1 if p_corr[j]==corr[j] else 0 for j in range(len(corr))]))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "for bmrk in benchmarks.keys():\n",
    "    print(bmrk+' cost MAE:' + str(np.mean(benchmarks[bmrk][0])))\n",
    "    print(bmrk+' performance acc:' + str(np.mean(benchmarks[bmrk][1])))"
   ],
   "outputs": [],
   "metadata": {}
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}