{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# LLM (gpt-4o) as a judge"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "import openai\n",
    "from tqdm import tqdm\n",
    "import pickle\n",
    "import os.path\n",
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import re\n",
    "\n",
    "import pandas as pd\n",
    "import scipy.stats as sps"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Eval one sample / test openai server"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys; sys.path.insert(0, '..')\n",
    "from utils import levels, prompt, reminder, llm_as_a_judge\n",
    "from scripts.run_collab_limo import limo_conversation_converter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"openai_config.json\", \"r\") as f:\n",
    "    openai_config = json.loads(\"\".join(f.readlines()))\n",
    "\n",
    "client = openai.OpenAI(\n",
    "    **openai_config\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<>:1: SyntaxWarning: invalid escape sequence '\\{'\n",
      "<>:1: SyntaxWarning: invalid escape sequence '\\{'\n",
      "/var/tmp/ipykernel_759362/1734098637.py:1: SyntaxWarning: invalid escape sequence '\\{'\n",
      "  conversation = \"\"\"\n"
     ]
    }
   ],
   "source": [
    "conversation = \"\"\"\n",
    "# Solve the following problem\n",
    "\n",
    "Alice and Bob, you will now solve the next problem together. Keep track of who does what work and communicate to avoid doing the same work twice.\n",
    "\n",
    "For how many pairs of consecutive integers in $\\{1000,1001,1002^{}_{},\\ldots,2000\\}$ is no carrying required when the two integers are added?<|im_end|>\n",
    "<|im_start|>assistant\n",
    "<think>\n",
    "**Bob [1]:** Hi, I'm Bob. Let me suggest we split the problem. Since consecutive integers differ by 1, each pair is (n, n+1). We need to check if adding them has no carrying in any digit. Since we're dealing with numbers from 1000 to 2000, all numbers are four-digit numbers starting with 1 or 2. Wait, actually 2000 is included, but 2000+1=2001 which is still within the set. Let me clarify the exact range. The set is {1000,1001,...,2000}. So pairs are (1000,1001), (1001,1002), ..., (1999,2000). So total pairs: 2000 -1000 = 1000 numbers, so 1000 pairs? Wait, actually from 1000 to 2000 inclusive, there are 1001 numbers, so 1000 pairs. \n",
    "\n",
    "\n",
    "\n",
    "### Work in progress (others)\n",
    "\n",
    "**Alice [1]:**Hi, I'm Alice. Here's how we can tackle this problem: We need to count the number of consecutive integer pairs between 1000 and 2000 where adding them doesn't require carrying in any digit. Let me think. Since consecutive numbers like n and n+1, their digits differ in some places. Adding them might cause carries. Wait, actually, when adding n + (n+1) = 2n +1. Hmm, but the question is about adding the two consecutive integers, not their sum. Wait, the problem says \"no carrying required when the two integers are added\". So for each pair (n, n+1), when you add n and n+1, there should be no carrying in any digit. Let me confirm: for example, adding 100 and 101: 100 + 101 = 201, which has no carries. But 109 + 110 = 219, but wait, 109 +110 would actually be 219? Wait, no, 109 +110 is 219, but actually adding 109 and 110: the units digit: 9<...>\n",
    "\n",
    "**Bob [2]:** Quick check: am I doing redundant work? (yes/no): 109+110=219. Wait, adding digit-wise: 9+0=<...>\n",
    "\n",
    "\n",
    "\n",
    "Wait, given the limited time, I have to give an answer right now. Considering all my previous attempts, I have to conclude that the final answer is \\\\boxed{100}. But I'm not sure. Wait, let me think again\n",
    "\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "# Solve the following problem\n",
      "\n",
      "Alice and Bob, you will now solve the next problem together. Keep track of who does what work and communicate to avoid doing the same work twice.\n",
      "\n",
      "For how many pairs of consecutive integers in $\\{1000,1001,1002^{}_{},\\ldots,2000\\}$ is no carrying required when the two integers are added?<|im_end|>\n",
      "<|im_start|>assistant\n",
      "<think>\n",
      "**Bob [1]:**  Let me suggest we split the problem. Since consecutive integers differ by 1, each pair is (n, n+1). We need to check if adding them has no carrying in any digit. Since we're dealing with numbers from 1000 to 2000, all numbers are four-digit numbers starting with 1 or 2. Wait, actually 2000 is included, but 2000+1=2001 which is still within the set. Let me clarify the exact range. The set is {1000,1001,...,2000}. So pairs are (1000,1001), (1001,1002), ..., (1999,2000). So total pairs: 2000 -1000 = 1000 numbers, so 1000 pairs? Wait, actually from 1000 to 2000 inclusive, there are 1001 numbers, so 1000 pairs. \n",
      "\n",
      "\n",
      "\n",
      "### Work in progress (others)\n",
      "\n",
      "**Alice [1]:** We need to count the number of consecutive integer pairs between 1000 and 2000 where adding them doesn't require carrying in any digit. Let me think. Since consecutive numbers like n and n+1, their digits differ in some places. Adding them might cause carries. Wait, actually, when adding n + (n+1) = 2n +1. Hmm, but the question is about adding the two consecutive integers, not their sum. Wait, the problem says \"no carrying required when the two integers are added\". So for each pair (n, n+1), when you add n and n+1, there should be no carrying in any digit. Let me confirm: for example, adding 100 and 101: 100 + 101 = 201, which has no carries. But 109 + 110 = 219, but wait, 109 +110 would actually be 219? Wait, no, 109 +110 is 219, but actually adding 109 and 110: the units digit: 9<...>\n",
      "\n",
      "**Bob [2]:**  109+110=219. Wait, adding digit-wise: 9+0=<...>\n",
      "\n",
      "\n",
      "\n",
      "Wait, given the limited time, I have to give an answer right now. Considering all my previous attempts, I have to conclude that the final answer is \\boxed{100}. But I'm not sure. Wait, let me think again\n",
      "\n"
     ]
    }
   ],
   "source": [
    "conversation = limo_conversation_converter(conversation)\n",
    "print(conversation)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The collaboration level between Alice and Bob can be analyzed as follows:\n",
      "\n",
      "1. **No collaboration:** The conversation doesn't fall into this category because both Alice and Bob acknowledge the problem they need to solve and make parallel, albeit independent, attempts to contribute towards a solution.\n",
      "\n",
      "2. **Initial Communication:** This level is characterized by workers exchanging information without building upon each other's ideas, often working independently. Alice and Bob each try to understand the problem but do not effectively communicate with each other. While they work on the same problem, they operate independently, as evidenced by Bob summarizing the range of numbers and Alice clarifying the concept of carrying. There seems to be minimal direct acknowledgment of each other's progress or insights.\n",
      "\n",
      "3. **Paying attention:** This level involves paraphrasing or summarizing others' points to show understanding, which neither Alice nor Bob significantly demonstrate in this interaction. Alice and Bob's contributions are mostly independent, with little to no integration or validation of each other's ideas.\n",
      "\n",
      "4. **Regular discussion:** Key characteristics of this level, such as regular discussion and re-using of ideas, planning, or work-splitting, are not present in Alice and Bob's interaction. They do not discuss or coordinate their tasks effectively, nor do they adapt their strategies based on each other's input.\n",
      "\n",
      "5. **Adaptive Problem-Solving:** This involves high responsiveness and a perfect division of labor, with continuous discussion and plan adjustments. Alice and Bob do not engage at this level of collaboration.\n",
      "\n",
      "6. **Optimal collaboration:** This level is reserved for instances where workers understand each other instantly and adapt optimally. The interaction between Alice and Bob does not exhibit these characteristics.\n",
      "\n",
      "The conversation is characterized by minimal engagement with each other's work and a lack of effective communication. They both work on the problem in isolation without integrating insights or coordinating efforts. This fits the pattern described in level 2, where there is an initial communication, but no collaborative integration or building upon each other's ideas is evident.\n",
      "\n",
      "Thus, the level of collaboration for this interaction is best captured by level \\boxed{2}. Alice and Bob acknowledge the task but primarily work independently without effectively responding to each other’s contributions.\n",
      "2\n"
     ]
    }
   ],
   "source": [
    "ans = \\\n",
    "client.chat.completions.create(\n",
    "    model=\"gpt-4o\",\n",
    "    messages=[\n",
    "        {\"role\": \"system\", \"content\": prompt},\n",
    "        {\"role\": \"user\", \"content\": conversation},\n",
    "        {\"role\": \"system\", \"content\": reminder},\n",
    "        ]\n",
    ")\n",
    "\n",
    "ans_str_1 = ans.response[\"choices\"][0][\"message\"][\"content\"]\n",
    "score = re.search(r'\\\\boxed\\{(.*?)\\}',ans_str_1).group(1)\n",
    "print(ans_str_1)\n",
    "print(int(score))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The conversation between Alice and Bob deserves level 2 for the following reasons:\n",
      "\n",
      "1. **Acknowledgment of the Task:** Both Alice and Bob are aware of the task at hand and make attempts to contribute independently, which indicates that they are not completely ignoring each other's presence. For example, Bob starts by suggesting a split in the problem and clarifies the range of numbers, which shows an initial attempt to set the stage for solving the problem.\n",
      "\n",
      "2. **Independent Attempts to Solve the Problem:** Alice and Bob each try to interpret the problem and think out loud about possible solutions:\n",
      "   - Bob is attempting to calculate the total number of pairs and expresses confusion about the range of numbers, indicating he is working on understanding the problem.\n",
      "   - Alice focuses on the concept of carrying and attempts to clarify what \"no carrying\" means in the context of the problem.\n",
      "\n",
      "3. **Initial Communication:** There are signs of both workers trying to understand the problem, even if they do not build upon each other's ideas. For instance, Bob's mention of splitting the problem (\"Let me suggest we split the problem\") shows an intention to coordinate, even if it isn't followed through effectively.\n",
      "\n",
      "These points indicate that Alice and Bob are engaged in the problem and have some level of initial communication, albeit ineffective, which distinguishes this from level 1, where there would be no signs of collaboration. However, their efforts are largely uncoordinated, which is why it doesn't progress to a higher level.\n",
      "\n",
      "Therefore, while they each independently acknowledge the task and make solo attempts to solve it, the interaction lacks effective collaboration beyond initial communication attempts. This justifies assigning the conversation a level of \\boxed{2}.\n"
     ]
    }
   ],
   "source": [
    "ans = \\\n",
    "client.chat.completions.create(\n",
    "    model=\"gpt-4o\",\n",
    "    messages=[\n",
    "        {\"role\": \"system\", \"content\": prompt},\n",
    "        {\"role\": \"user\", \"content\": conversation},\n",
    "        {\"role\": \"system\", \"content\": reminder},\n",
    "        {\"role\": \"assistant\", \"content\": ans_str_1},\n",
    "        {\"role\": \"user\", \"content\": \"Why do you think it deserves level 2? Why not level 1? Provide supportive examples from their conversations.\"}\n",
    "        ]\n",
    ")\n",
    "ans_str_2 = ans.response[\"choices\"][0][\"message\"][\"content\"]\n",
    "print(ans_str_2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "If this conversation is indeed level 1, it indicates that my initial identification of minimal acknowledgment and communication was overestimated. Here's a breakdown of what might have been misunderstood or lacking in identifying it as level 1:\n",
      "\n",
      "1. **Acknowledgment as Surface-Level:** The acknowledgment of the task could be surface-level without any intention to engage in meaningful dialogue or collaboration. Both workers are simply stating the obvious or repeating parts of the problem without actually communicating with each other.\n",
      "\n",
      "2. **Independent Monologs:** Alice and Bob might be entirely focused on their own understanding of the problem without any genuine attempt to integrate or consider the other's ideas. Their contributions do not reference or build upon one another, nor do they recognize each other's contributions beyond reading the task prompt.\n",
      "\n",
      "3. **Lack of Constructive Engagement:** The conversation lacks any form of meaningful engagement, such as direct responses or validations of each other's ideas. Instead, they might just be verbalizing their thoughts independently without any intention of collaboration.\n",
      "\n",
      "4. **No Intentional Collaboration Plan:** Bob's initial suggestion to split the problem might not be followed through or genuinely considered, which indicates a lack of purposeful coordination or planning beyond stating the task.\n",
      "\n",
      "5. **No effective Introduction:** The basic introduction or initial attempt to communicate should lack genuine acknowledgment, meaning they might not even recognize that they're working with someone else.\n",
      "\n",
      "If these elements were present, it would justify describing the interaction as level 1, where the participants do not genuinely engage or acknowledge the potential for collaboration, and simply work independently without any functional attempt to solve the problem together. Such a lack of connection or engagement would align more accurately with the description of level 1 collaboration.\n"
     ]
    }
   ],
   "source": [
    "ans = \\\n",
    "client.chat.completions.create(\n",
    "    model=\"gpt-4o\",\n",
    "    messages=[\n",
    "        {\"role\": \"system\", \"content\": prompt},\n",
    "        {\"role\": \"user\", \"content\": conversation},\n",
    "        {\"role\": \"system\", \"content\": reminder},\n",
    "        {\"role\": \"assistant\", \"content\": ans_str_1},\n",
    "        {\"role\": \"user\", \"content\": \"Why do you think it deserves level 2? Why not level 1?\"},\n",
    "        {\"role\": \"assistant\", \"content\": ans_str_2},\n",
    "        {\"role\": \"user\", \"content\": \"If I was to tell you that this is in fact level 1 what would you lack back at the beginning to identify that?\"},\n",
    "        ]\n",
    ")\n",
    "ans_str_3 = ans.response[\"choices\"][0][\"message\"][\"content\"]\n",
    "print(ans_str_3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "To evaluate on any other dataset / generations you may need to specify path to your generation, where to save logs, and conversation handling (such as removing s1 or other insertions, removing prompt, removing few-shot etc.).\n",
    "\n",
    "I suggest using `run_limo_collab_eval.py` as baseline."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collab Comparasing"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Metadata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "metadata = {\n",
    "        \"limo-QwQ-main\": \n",
    "        {\"source_path\": \"generations/LIMO/QwQ-main/limo/QwQ-32B-seed-42-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "        \"save_path\"  : \"judge_results/LIMO/QwQ-main/it1_long/QwQ-32B-seed-42-budget-{budget}.pkl\",\n",
    "        \"model_name\": \"QwQ-32B\",\n",
    "        \"size\": 32,\n",
    "        \"layout\" : \"combined\"\n",
    "        },\n",
    "\n",
    "        \"limo-QwQ-ablation-interleaved\": \n",
    "        {\"source_path\": \"generations/LIMO/QwQ-ablation-interleaved/evals_data/limo/QwQ-32B-seed-42-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "        \"save_path\"  : \"judge_results/LIMO/QwQ-ablation-interleaved/it1_long/QwQ-32B-seed-42-budget-{budget}.pkl\",\n",
    "        \"model_name\": \"QwQ-32B\",\n",
    "        \"size\": 32,\n",
    "        \"layout\" : \"interleaved\"\n",
    "        },\n",
    "\n",
    "        \"limo-QwQ-ablation-independent\": \n",
    "        {\"source_path\": \"generations/LIMO/QwQ-ablation-independent/evals_data/limo/QwQ-32B-seed-{seed}-budget-{budget}/Task_{task}.txt\",\n",
    "        \"save_path\"  : \"judge_results/LIMO/QwQ-ablation-independent/it1_long/QwQ-32B-ablation-independent-budget-{budget}.pkl\",\n",
    "        \"model_name\": \"QwQ-32B\",\n",
    "        \"size\": 32,\n",
    "        \"layout\" : \"independent\"\n",
    "        },\n",
    "\n",
    "        #############\n",
    "\n",
    "        \"limo-phi4-main\": \n",
    "        {\"source_path\": \"generations/LIMO/phi4-main/eval_data/limo/Phi-4-reasoning-plus-seed-42-budget-256-{budget}-hogwild/Task_{task}.txt\",\n",
    "         \"save_path\"  : \"judge_results/LIMO/phi4-main/it1/Phi-4-reasoning-plus-seed-42-budget-{budget}.pkl\",\n",
    "         \"model_name\": \"Phi-4-R+\",\n",
    "         \"size\": 14,\n",
    "         \"layout\" : \"combined\"\n",
    "         },\n",
    "\n",
    "         \"limo-phi4-ablation-independent\": \n",
    "        {\"source_path\": \"generations/LIMO/phi4-ablation-independent/evals_data/limo/Phi-4-reasoning-plus-seed-{seed}-budget-{budget}/Task_{task}.txt\",\n",
    "         \"save_path\"  : \"judge_results/LIMO/phi4-ablation-independent/it1_long/Phi-4-reasoning-plus-seed-{budget}.pkl\",\n",
    "         \"model_name\": \"Phi-4-R+\",\n",
    "         \"size\": 14,\n",
    "         \"layout\" : \"independent\"\n",
    "         },\n",
    "\n",
    "         \"limo-phi4-ablation-interleaved\": \n",
    "        {\"source_path\": \"generations/LIMO/phi4-ablation-interleaved/evals_data/limo/Phi-4-reasoning-plus-seed-42-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "         \"save_path\"  : \"judge_results/LIMO/phi4-ablation-interleaved/it1_long/Phi-4-reasoning-plus-seed-42-budget-{budget}.pkl\",\n",
    "         \"model_name\": \"Phi-4-R+\",\n",
    "         \"size\": 14,\n",
    "         \"layout\" : \"interleaved\"\n",
    "         },\n",
    "\n",
    "        #############\n",
    "\n",
    "         \"limo-Qwen-8B-main\": \n",
    "        {\"source_path\": \"generations/LIMO/Qwen-8B-main/evals_data/limo/Qwen3-8B-seed-0-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "         \"save_path\"  : \"judge_results/LIMO/Qwen-8B-main/it1/Qwen3-8B-seed-0-budget-{budget}.pkl\",\n",
    "         \"model_name\": \"Qwen3-8B\",\n",
    "         \"size\": 8,\n",
    "         \"layout\" : \"combined\"\n",
    "         },\n",
    "\n",
    "         \"limo-Qwen-8B-ablation-interleaved\": \n",
    "        {\"source_path\": \"generations/LIMO/Qwen-8B-ablation-interleaved/evals_data/limo/Qwen3-8B-seed-42-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "        \"save_path\"  : \"judge_results/LIMO/Qwen-8B-ablation-interleaved/it1_long/Qwen3-8B-seed-42-budget-{budget}.pkl\",\n",
    "        \"model_name\": \"Qwen3-8B\",\n",
    "        \"size\": 8,\n",
    "        \"layout\" : \"interleaved\"\n",
    "        },\n",
    "\n",
    "         \"limo-Qwen-8B-ablation-independent\": \n",
    "        {\"source_path\": \"generations/LIMO/Qwen-8B-ablation-independent/evals_data/limo/Qwen3-8B-seed-{seed}-budget-{budget}-hogwild/Task_{task}.txt\",\n",
    "         \"save_path\"  : \"judge_results/LIMO/Qwen-8B-ablation-independent/it1_long/Qwen3-8B-seed-{budget}.pkl\",\n",
    "         \"model_name\": \"Qwen3-8B\",\n",
    "         \"size\": 8,\n",
    "         \"layout\" : \"independent\"\n",
    "         },\n",
    "    }"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "# get table\n",
    "budget_grid = [\n",
    "        2048,\n",
    "        4096,\n",
    "] \n",
    "colors = [\"red\", \"green\", \"blue\", \"magenta\", \"orange\"]\n",
    "\n",
    "color_dict = dict(zip(metadata.keys(), (colors * 4)[:len(metadata.keys())]))\n",
    "\n",
    "df = []\n",
    "for name, meta in metadata.items():\n",
    "  save_path = meta[\"save_path\"]\n",
    "  name = name[5:]\n",
    "  for budget in budget_grid:\n",
    "    with open(save_path.format(budget=budget), 'rb') as f:\n",
    "      scores = pickle.load(f)\n",
    "    try:\n",
    "      values = np.array([float(score) for score, s in scores.values() if not score is None])\n",
    "      mean_score = sum(values)/len(values)\n",
    "    except:\n",
    "      print(\"Error on \", name)\n",
    "      break\n",
    "\n",
    "    bs = sps.bootstrap([values], np.mean, confidence_level=0.95)\n",
    "    df.append((meta[\"model_name\"], budget, meta[\"size\"], meta[\"layout\"], mean_score, bs.standard_error, color_dict[f\"limo-{name}\"]))\n",
    "\n",
    "df = pd.DataFrame(df, columns=[\"name\", \"budget\", \"size\", \"layout\", \"mean\", \"std\", \"color\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ERER0QciK0l89+4d2rRpgxs3bgBITwzLly8PQ0NDREZGYurUqTh//jwOHTrEFc5ERERERZCsqb4lS5bg1q1bGD16NAIDAxEREYHr16/j4sWLePToEcLDwyGEwPr16zUdLxEREREVAFlJ4p49e7Bjxw6sXbsWVapUUau3sbHB3r17sXfv3nwHSEREREQFT/ZDg3379s223tjYGO/evZM7PBERERFpkawk0crKKsc2Dx8+RFhYmJzhiYiIiEjLZCWJNWrUwNatW7OsP3nyJDw8PNC0aVPZgRERERGR9sha3TxjxgzUq1cPu3fvRps2bWBtbY03b94gLCwMx48fR3BwMAwNDTFv3jxNx0tEREREBUBWkujg4IDTp0+jX79+mDFjhso2N0II2NjYYM+ePahRo4bGAiUiIiKigiN7M+3atWvj7t27OHLkCI4fP46nT5/CzMwMLVq0QP/+/VGyZElNxklEREREBUh2kggAurq68PT0hKenp4bCISIiIqLCQPYWOE+ePMHq1avx9u1bqSwgIABLlixBUFCQJmIjIiIiIi2RNZP4559/wt3dHdHR0dDT08Po0aMBAC4uLjA3N4eXlxf69++PMWPGaDRYIiIiIioYslc3Jycno1WrVujUqZNKXbly5bBlyxbUrFkTVlZW6NWrl0YCJSIiIqKCI+t284MHDxAUFIQzZ86gYsWKavXVqlVDuXLl4OPjk9/4iIiIiEgLZM0kWllZwdbWNsv61NRUxMbGIioqSnZgRERERKQ9smYSLSwsEBwcnGX90qVLERsbC3t7e9mBEREREZH2yEoSJ06ciHbt2uHQoUNISUkBACiVSly/fh29evXC7NmzoVAoMHz4cI0GS0REREQFQ9btZg8PDwwdOhTdu3eHjo4OrK2tERUVhdTUVAghAAC9e/fGpEmTNBosERERERUM2fskTps2Df7+/vj000+hVCohhECpUqXQrl077N27F7t371Y5ri8vEhISMGXKFFSoUAGGhoZwcnLC9OnTER8fn6dx9u3bh/r168PNzQ1NmjTBmTNnZMVDRERE9LHJ14krzZs3R/PmzTUVC4D0s5+7du2K33//HeXKlYOOjg6Cg4OxePFinDlzBv7+/jAxMclxnMWLF2P58uW4ePEiPvnkE5w/fx4dOnTArl270L17d43GTERERFTcyJ5J/FA2b96M5ORkBAYG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gqygiIiIiEi7csz+Jk2aJHtwJolERERERRM3NiQiIiIiNUwSiYiIiEgNk0QiIiIiUsMkkYiIiIjUFPokMTIyErNmzYKrq6us/ocOHYJCoVB7nTp1SrOBEhERERUjudpMWxtiYmKwevVq/PjjjwgPD0eFChVkjbN48WLo6uqqlNWoUQPt27fXRJhERERExVKhTRKNjY0xbdo0eHl5oUaNGrLGOHv2LGxtbZGamqrh6IiIiIiKt0KbJOrppYfm7OwsewwfHx98++23mgqJiIiI6KNR6J9J1NfXl9Xv5s2bOHv2LObOnYulS5fi2bNnGo6MiIiIqPgq9EmiXD4+PlAqlfDz88PUqVPh6OiIqVOnIiUlRduhERERERV6hfZ2c34NGDAAnTp1wu3bt3HkyBE8ffoUS5cuxZ07d3Ds2DHZM5REpAFzzbUdgXyODtqOgIioQBTbmcRu3bphyJAh+OGHHxAUFIQ5c+ZAoVDg9OnTmDt3bpb9VqxYAXt7e+kVFxdXcEETERERFRLFNkl8n5GREebOnYvvv/8eALBmzRokJydn2nbixIkIDw+XXqampgUZKhEREVGh8FEkiRm++uor1K9fH7GxsXj48KG2wyEiIiIqtD6qJBEABg4cCABcwEJERESUjY8uSaxUqRL09fVRpUoVbYdCREREVGh9dEni8+fP4enpCQsLC22HQkRERFRoFfokUalUAgDS0tIyrT916hQaNGiAU6dO5ThWWloafvnlFyxdulSjMRIREREVN4U+SQwICAAAREZGIjIyUq1+1apVuHHjBlavXi2Vbd68GRYWFpgxY4a0hc3bt28xZcoULFiwABUrViyQ2ImIiIiKqkKdJLq5uaF+/foAgHfv3qFKlSro0aOHSpsePXrAzMwMPXv2lMrc3d3h6uqKNWvWoHLlyhgwYAC2b9+OuXPnol69egV6DURERERFUaE+ceX27ds5thk0aBAGDRqkUubs7Ax/f/8PFBURERFR8VeoZxKJiIiISDuYJBIRERGRGiaJRERERKSGSSIRERERqWGSSERERERqmCQSERERkRomiURERESkhkkiEREREalhkkhEREREapgkEhEREZEaJolEREREpIZJIhERERGpYZJIRERERGqYJBIRERGRGiaJRERERKSGSSIRERERqWGSSERERERqmCQSERERkRomiURERESkhkki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",
      "text/plain": [
       "<Figure size 640x440 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df['layout'] = pd.Categorical(df['layout'], [\"independent\", \"interleaved\", \"combined\"])\n",
    "df = df.sort_values(by=[\"layout\"])\n",
    "\n",
    "budget = 4096\n",
    "df = df[df[\"budget\"] == budget]\n",
    "colors = [\"tab:orange\", \"tab:green\", \"tab:blue\"]\n",
    "\n",
    "plt.rcParams.update({'font.size': 21, 'font.family': 'Times New Roman'})\n",
    "fig, ax = plt.subplots(layout='constrained', figsize=(8, 5.5), dpi=80)\n",
    "\n",
    "x = np.arange(3)\n",
    "width = 0.25\n",
    "multiplier = 0\n",
    "\n",
    "for name, color in zip([\"Qwen3-8B\", \"Phi-4-R+\", \"QwQ-32B\"], colors):\n",
    "    mean = df[df[\"name\"] == name][\"mean\"]\n",
    "    layout = df[df[\"name\"] == name][\"layout\"]\n",
    "    rects = ax.bar(x + width * multiplier, mean.round(2), width, label=name, color=color)\n",
    "    multiplier += 1\n",
    "    # ax.bar_label(rects, padding=3)\n",
    "\n",
    "plt.legend(loc='upper left', ncols=1)\n",
    "plt.ylabel(\"Mean collaborative score\")\n",
    "ax.set_xticks(x + width, [\"No sync\", \"Step-wise\", \"Token-wise\"])\n",
    "plt.ylim([1, 4])\n",
    "# plt.show()\n",
    "fig.savefig(\"main_analysis.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".llmfork",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
