{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import pandas as pd \n",
    "import matplotlib.pyplot as plt\n",
    "from src.compile_results import compile_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"response_evaluation/math_rewritten_temp.csv\", index_col=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "       Correctly rewritten?  DSReason+basicprompt BEFORE  \\\n",
      "Total                  24.0                           15   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     0.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     0.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     NaN                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     0.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            1   \n",
      "NaN                     0.0                            0   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     0.0                            0   \n",
      "NaN                     1.0                            0   \n",
      "NaN                     1.0                            0   \n",
      "\n",
      "       DSReason+basicprompt AFTER  Qwen70+basicprompt BEFORE  \\\n",
      "Total                          19                          7   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          1   \n",
      "NaN                             1                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          1   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          1   \n",
      "NaN                             1                          1   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          1   \n",
      "NaN                             1                          1   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          1   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          0   \n",
      "NaN                             0                          0   \n",
      "NaN                             1                          0   \n",
      "\n",
      "       Qwen70+basicprompt AFTER  GPT-o3+basicprompt BEFORE  \\\n",
      "Total                        10                         17   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          1   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           0                          1   \n",
      "NaN                           1                          1   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          1   \n",
      "NaN                           1                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          0   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           1                          0   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           0                          1   \n",
      "NaN                           0                          0   \n",
      "NaN                           0                          1   \n",
      "\n",
      "      GPT-o3+basicprompt AFTER  \n",
      "Total                       22  \n",
      "NaN                        NaN  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                        NaN  \n",
      "NaN                             \n",
      "NaN                        NaN  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          0  \n",
      "NaN                          1  \n",
      "NaN                        NaN  \n",
      "NaN                          0  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          0  \n",
      "NaN                          1  \n",
      "NaN                          1  \n",
      "NaN                          1  \n"
     ]
    }
   ],
   "source": [
    "print(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Before Rewriting': (7, 15, 17), 'After Rewriting': (10, 19, 22)}\n"
     ]
    },
    {
     "data": {
      "image/png": "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w+IzzzzjMI/csPnRRx8VaJ3btGlj70Hy8/Mzc+fOzXd+33//fZ739urVy7i7u190/oWxD7788svGy8vL3gP3+OOPm7Zt25o6derYg9Zff/1lJJmpU6fa52N1XOSOyw2Lxpzrrcyvh8kYY8aOHWskmT179ji079u3z7i6upp+/fo5tB8/ftyEhoY6BNeCHgdWIiMjjZeXl/nzzz/tbZs2bTKSTFhYmENP1Pz5840k89VXX1nOLysry5w4ccL4+PiYN954w97+2Wef5ek5zZW7PX/88UeH9ho1apg2bdpcch0kGS8vL5OWluZQR7Vq1UylSpXsbblhsUePHg7vv5LPxC+//NJh2p49e5oSJUqYP/74w6Gu83/vTzzxhClZsqTDNMYYM27cOCPJ/k9A7r5dt25dh+N14sSJRpLp2LGjw/sHDBhgJNn/0SjIZxmKJy5wQbGxcuVKSVJiYqJDe6NGjVS9enWtWLHCob106dK68847851Xx44d5ebmZh/etWuXfvvtNz300EOSpKysLPurXbt2Sk1N1fbt2yVJ33zzjeLi4lS9evUrXhebzaYOHTo4tNWpU0d//PGHfXjBggUqVaqUOnTo4FBPvXr1FBoaar/woF69enJ3d1evXr00c+ZM/f7773mW16hRIx09elQPPvigvvzyS/3zzz8FqvPbb7+Vj4+P7r33Xof23N/Bhds8Li5Ovr6+9uGQkBAFBwc7rNfl2L59u/7++291795dJUr838dRyZIl1aVLF/3www86deqUw3tyf4e57r//frm6utr3n0t566239NNPP+nLL79UmzZt1LVrV33yySd5prM6V6yg55BdzT7YokULnT59WmvXrpX0f1dyt2zZUsuWLbO3SVLLli0dlnux4+JqLVmyRFlZWerRo4dD/Z6enoqJiclzsUxBjoOLqVevnsqWLWsfzj0mY2NjHc5Pzm0/f74nTpzQoEGDVKlSJbm6usrV1VUlS5bUyZMntW3btgKvc2hoqBo1anTF69CiRQuFhITYh11cXNS1a1ft2rVLf/75p8O0Xbp0cRi+3M9EX19fdezY0aGtW7duysnJ0apVqyxrXLBggeLi4hQeHu7we42Pj5d07oKv87Vr187heM3d/nfddZfDdLnt+/btk1SwzzIUT4RFXDNBQUHy9vbWnj17CjT94cOHJUlhYWF5xoWHh9vH58pvOqtxBw4ckCQ9++yzcnNzc3j16dNHkuwB69ChQypXrlyBarbi7e0tT09PhzYPDw+dOXPGoaajR4/K3d09T01paWn2eipWrKjly5crODhYffv2VcWKFVWxYkW98cYb9nl1795d06dP1x9//KEuXbooODhYjRs3tgcLK4cPH1ZoaGieABQcHCxXV9c82zwwMDDPPDw8PHT69OmCbZh8li9Z/85zcnJ05MgRh/bQ0FCHYVdXVwUGBuap1UrlypXVsGFDdezYUZ9++qlatGihvn37KicnR9L/rWN+8/v3338VEBBQoOVczT7YrFkzeXt7a/ny5dq1a5f27t1rD4s//vijTpw4oeXLl6tChQqKjo6+6HILU+46NGzYMM86zJkzJ88/KQU5Di7mwm3t7u5+0fbz59utWzdNmjRJjz/+uJYsWaKffvpJ69atU5kyZS5rf73aff7C/fX8tkt9pl3uZ+L5ofRSyzrfgQMH9PXXX+f5ndasWVOS8vxer/T3UpDPMhRPXA2Na8bFxUUtWrTQN998oz///POSASz3Qzk1NTXPtH///beCgoIc2i7Ww3PhuNz3Dh48WPfcc0++76lataokqUyZMnn+478WgoKCFBgYaHk1+Pk9eM2bN1fz5s2VnZ2tn3/+WW+99ZYGDBigkJAQPfDAA5KkRx55RI888ohOnjypVatWaejQoWrfvr127NihyMjIfJcRGBioH3/8UcYYh2128OBBZWVl5dnmhe383/mF/v77b5UoUUKlS5d2aE9LS3PobcrKytLhw4fz/aNeEI0aNdLixYt16NAhhYSE2O9Vt2XLFrVr185h2i1btlzWvezOdzn7oLu7u26//XYtX75c5cqVU2hoqGrXrq0KFSpIkpKTk7VixQq1b9/+ksstTLnr8Pnnn1vuU8XBsWPHtGDBAg0dOlQvvPCCvT0jI6PI7+ualpZm2XbhPnvh7+5yPxNzw3xBlnW+oKAg1alTR6+++mq+48PDwy3fe7kK8lmG4oeeRVxTgwcPljFGPXv2VGZmZp7xZ8+e1ddffy1J9q/OLrzn3bp167Rt2za1aNHiiuuoWrWqKleurF9++UUNGjTI95UbzuLj47Vy5Ur7V4L5yb0FypX2qEnnbtty+PBhZWdn51tPbnA4n4uLixo3bqy3335bkrRhw4Y80/j4+Cg+Pl4vvfSSMjMztXXrVssaWrRooRMnTmj+/PkO7R9++KF9fGGw2l5Vq1ZV2bJl9fHHH8sYY28/efKkvvjiC/tNsc83a9Ysh+FPP/1UWVlZDjecLihjjFJSUlSqVCn7H9OyZcuqUaNG+uijj5SdnW2f9ocfftD27dstg96lXM4+KJ37enn9+vX64osv7F81+/j4qEmTJnrrrbf0999/5/kK+nJcbB+2GtemTRu5urpq9+7dlutQHNhsNhlj8tyq6P3333f4nUqFcyxfzIoVKxxCXHZ2tubMmaOKFSte8h/oy/1MPH78uL766iuHto8//lglSpTQHXfcYbmc9u3b69dff1XFihXz/Z0WZljMVZDPMhQf9CzimmratKneeecd9enTR/Xr11fv3r1Vs2ZNnT17Vhs3btTUqVNVq1YtdejQQVWrVlWvXr301ltvqUSJEoqPj9fevXv1yiuvKCIiQs8888xV1fLuu+8qPj5ebdq0UWJiosqWLat///1X27Zt04YNG/TZZ59JkoYPH65vvvlGd9xxh1588UXVrl1bR48e1eLFizVw4EBVq1ZNFStWlJeXl2bNmqXq1aurZMmSCg8Pv6wP1QceeECzZs1Su3bt1L9/fzVq1Ehubm76888/tXLlSnXq1El33323pkyZom+//VZ33XWXypcvrzNnzmj69OmS/u98tZ49e8rLy0u33XabwsLClJaWplGjRsnf318NGza0rKFHjx56++23lZCQoL1796p27dpavXq1Ro4cqXbt2l1VGDnfxbbXmDFj9NBDD6l9+/Z64oknlJGRobFjx+ro0aN67bXX8sxr7ty5cnV1VatWrbR161a98sorqlu3ru6///6L1tCpUyfVrVtX9erVU2BgoP7++2998MEHSklJ0dtvv22/n6IkjR49Wq1atdJ9992nPn366ODBg3rhhRdUq1YtPfLII1e8HQq6D0rngnp2drZWrFihmTNn2ttbtmypoUOHymazXdW5ib6+voqMjNSXX36pFi1aKCAgQEFBQYqKilLt2rUlSW+88YYSEhLk5uamqlWrKioqSsOHD9dLL72k33//XW3btlXp0qV14MAB/fTTT/Lx8dGwYcOuuKbC4ufnpzvuuENjx461r1NKSoqmTZumUqVKOUyb21M8depU+fr6ytPTU9HR0VfcU32hoKAg3XnnnXrllVfk4+OjyZMn67ffftPs2bMv+d7L/UwMDAxU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du7c6bDMQYMG6emnn9a2bdvUpk0bvffee3rppZf06quvatu2bRo5cqReeeUVzZw5s8Dr8fvvv2vx4sVyc3Ozt11qvrGxsUpOTrZPn5KSoqCgIKWkpEiS1q1bpzNnzui2226zTzNz5ky5urpqzZo1evfdd/PU8dNPP0mSli9frtTUVM2dO9ey5pkzZ8rHx0c//vijxowZo+HDh2vZsmWSzgXvzp07y9vbWz/++KOmTp2ql156qcDb42Y1Z84cVa1aVVWrVtXDDz+sGTNmKPeppG+88Yb9n5nU1FStW7dO69atk3Tun4rcNklasmSJHn74YT399NP63//+p3fffVcffPCBXn31VYflDR06VJ06ddKWLVv06KOPFqjGX375RWvWrHHYV19++WXNmDFD77zzjrZu3apnnnlGDz/8sH1fPH9fNcbou+++U+nSpbV69WpJ0sqVKxUaGqqqVava5zl27FjVqlVL69ev1yuvvOJQQ0REhL744gtJ0vbt25Wamqo33njDsubx48erQYMG2rhxo/r06aPevXvrt99+kyQdP35cHTp0UO3atbVhwwaNGDFCgwYNKtC2AHDj4wKX69SCBQtUsmRJSed6YsLCwrRgwQL7vc9mz56tEiVK6P3337f3Gs6YMUOlSpVScnKyWrdubf9KNTQ01D7fcePGadCgQXrggQckSaNHj9bKlSs1ceJEvf322/bpBgwYoHvuucc+PGLECI0fP97eFh0dbf8DnZCQcMn1yM7O1pkzZyRJEyZMKPB8Y2Nj1b9/f/3zzz9ycXHR1q1bNXToUCUnJ6tPnz5KTk5W/fr17dtKkipVqqQxY8ZY1lSmTBlJUmBgoMO2yU+dOnU0dOhQSVLlypU1adIkrVixwt7rtHv3biUnJ9vn8+qrr9p7M5G/adOm6eGHH5Z07jSFEydOaMWKFWrZsqX8/f3l6+tr/zr2fKVKlXJoe/XVV/XCCy/Y978KFSpoxIgRev755+2/M0nq1q1bgULi5MmT9f777+vs2bPKzMxUiRIl7MfEyZMnNWHCBH377bdq2rSpfXmrV6/Wu+++q5iYGMXGxmratGnKycnRli1b5OLioocffljJyclq166dkpOTFRMT47DMO++8U88++6x9OPebAenc85kDAgIkScHBwZc8RaJdu3b2UzwGDRqk119/XcnJyapWrZpmzZolm82m9957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jaCIYufDDz9UhQoVVLZsWf3yyy8aNGiQ7r///nyDIoCbC2ERuIaOHz+u559/Xvv371dQUJBatmzp8BQPoLhIS0vTkCFDlJaWprCwMN133315bmAO4ObE19B8jQIAl43PT+D6V9CvobkaGgAAAJYIi+LmswBwufjcBG4eN3VYzH2iwalTp5xcCQBcX3I/Ny98MgyAG89NfYGLi4uLSpUqZX8+qre3NzegBYCLMMbo1KlTOnjwoEqVKnXJR3oCuP7d1GFRkkJDQyXJHhgBAJdWqlQp++cngBvbTR8WbTabwsLCFBwcrLNnzzq7HAAo9tzc3OhRBG4iN31YzOXi4sKHHwAAwAVu6gtcAAAAcHGERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYMmpYXHUqFFq2LChfH19FRwcrM6dO2v79u0O0yQmJspmszm8mjRp4qSKAQAAbi5ODYspKSnq27evfvjhBy1btkxZWVlq3bq1Tp486TBd27ZtlZqaan8tWrTISRUDAADcXFydufDFixc7DM+YMUPBwcFav3697rjjDnu7h4eHQkNDi7o8AACAm16xOmfx2LFjkqSAgACH9uTkZAUHB6tKlSrq2bOnDh48aDmPjIwMpaenO7wAAABwZWzGGOPsIiTJGKNOnTrpyJEj+u677+ztc+bMUcmSJRUZGak9e/bolVdeUVZWltavXy8PD48880lKStKwYcPytB87dkx+fn7XdB0AAACuF+np6fL3979kRio2YbFv375auHChVq9erXLlyllOl5qaqsjISM2ePVv33HNPnvEZGRnKyMiwD6enpysiIoKwCAAAcJ6ChkWnnrOYq1+/fvrqq6+0atWqiwZFSQoLC1NkZKR27tyZ73gPD498exwBAABw+ZwaFo0x6tevn+bNm6fk5GRFR0df8j2HDx/W/v37FRYWVgQVAgAA3NyceoFL37599dFHH+njjz+Wr6+v0tLSlJaWptOnT0uSTpw4oWeffVbff/+99u7dq+TkZHXo0EFBQUG6++67nVk6AADATcGp5yzabLZ822fMmKHExESdPn1anTt31saNG3X06FGFhYUpLi5OI0aMUERERIGWUdDv4wEAAG4m18U5i5fKqV5eXlqyZEkRVQMAAIALFav7LAIAAKB4ISwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAgKRRo0apYcOG8vX1VXBwsDp37qzt27fbx589e1aDBg1S7dq15ePjo/DwcPXo0UN///23E6u+9giLAAAAklJSUtS3b1/98MMPWrZsmbKystS6dWudPHlSknTq1Clt2LBBr7zyijZs2KC5c+dqx44d6tixo5Mrv7Zsxhjj7CKupfT0dPn7++vYsWPy8/NzdjkAAOA6cejQIQUHByslJUV33HFHvtOsW7dOjRo10h9//KHy5csXcYVXp6AZiZ5FAACAfBw7dkySFBAQcNFpbDabSpUqVURVFT3CIgAAwAWMMRo4cKBuv/121apVK99pzpw5oxdeeEHdunW7ob+9dHV2AQAAAMXNU089pc2bN2v16tX5jj979qweeOAB5eTkaPLkyUVcXdEiLAIAAJynX79++uqrr7Rq1SqVK1cuz/izZ8/q/vvv1549e/Ttt9/e0L2KEmERAABA0rmvnvv166d58+YpOTlZ0dHReabJDYo7d+7UypUrFRgY6IRKixZhEQAAQFLfvn318ccf68svv5Svr6/S0tIkSf7+/vLy8lJWVpbuvfdebdiwQQsWLFB2drZ9moCAALm7uzuz/GuGW+cAAABIstls+bbPmDFDiYmJ2rt3b769jZK0cuVKxcbGXsPqCl9BMxI9iwAAADr3NfTFREVFXXKaGxG3zgEAAIAlwiIAAAAsERYBAABgibAIAAAAS1zgAgAArl9J/s6uoPAlHXN2BQ7oWQQAAIAlwiIAAAAsERYBAABgibAIAAAAS4RFAAAAWCIsAgAAwBJhEQAAAJYIiwAAALBEWAQAAIAlwiIAAAAsERYBAABgibAIAAAAS4RFAAAAWCIs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wsK0d+9evfjiizyrFQAAoAhd1TmL69ev17Zt22Sz2VSjRg3dcsstl/V+ntUKAABQvF1RWDx48KAeeOABJScnq1SpUjLG6NixY4qLi9Ps2bNVpkyZAs2HZ7UCAAAUb1d065x+/fopPT1dW7du1b///qsjR47o119/VXp6up5++unCrhEAAABOckU9i4sXL9by5ctVvXp1e1uNGjX09ttvX9MLXAAAAFC0rqhnMScnR25ubnna3dzclJOTc9VFAQAAoHi4orB45513qn///vr777/tbX/99ZeeeeYZtWjRotCKAwAAgHNdUVicNGmSjh8/rqioKFWsWFGVKlVSdHS0jh8/rrfeequwawQAAICTXNE5ixEREdqwYYOWLVum3377TcYY1ahRQy1btizs+gAAAOBEl9Wz+O2336pGjRpKT0+XJLVq1Ur9+vXT008/rYYNG6pmzZr67rvvrkmhAAAAKHqXFRYnTpyonj17ys/PL884f39/PfHEE5owYUKhFQcAAADnuqyw+Msvv6ht27aW41u3bq3169dfdVEAAAAoHi4rLB44cCDfW+bkcnV11aFDh666KAAAABQPlxUWy5Ytqy1btliO37x5s8LCwq66KAAAABQPlxUW27VrpyFDhujMmTN5xp0+fVpDhw5V+/btC604AAAAONdl3Trn5Zdf1ty5c1WlShU99dRTqlq1qmw2m7Zt26a3335b2dnZeumll65VrQAAAChilxUWQ0JCtHbtWvXu3VuDBw+WMUaSZLPZ1KZNG02ePFkhISHXpFAAAAAUvcu+KXdkZKQWLVqkI0eOaNeuXTLGqHLlyipduvS1qA8AAABOdEVPcJGk0qVLq2HDhoVZCwAAAIqZK3o2NAAAAG4OhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUUqVWrVqlDhw4KDw+XzWbT/PnzHcYbY5SUlKTw8HB5eXkpNjZWW7dudU6xAACAsIiidfLkSdWtW1eTJk3Kd/yYMWM0YcIETZo0SevWrVNoaKhatWql48ePF3GlAABAklydXQBuLvHx8YqPj893nDFGEydO1EsvvaR77rlHkjRz5kyFhITo448/1hNPPFGUpQIAANGziGJkz549SktLU+vWre1tHh4eiomJ0dq1a51YGQAANy/CIoqNtLQ0SVJISIhDe0hIiH0cAAAoWoRFFDs2m81h2BiTpw0AABQNwiKKjdDQUEnK04t48ODBPL2NAACgaBAWUWxER0crNDRUy5Yts7dlZmYqJSVFzZo1c2JlAADcvLgaGkXqxIkT2rVrl314z5492rRpkwICAlS+fHkNGDBAI0eOVOXKlVW5cmWNHDlS3t7e6tatmxOrBgDg5kVYRJH6+eefFRcXZx8eOHCgJCkhIUEffPCBnn/+eZ0+fVp9+vTRkSNH1LhxYy1dulS+vr7OKhkAgJsaYRFFKjY2VsYYy/E2m01JSUlKSkoquqIAAIAlp56zyKPfAAAAijenhkUe/QYAAFC8OfVraB79BgAAULwV21vnXOmj3zIyMpSenu7wAgAAwJUpthe4XOzRb3/88Yfl+0aNGqVhw4Zd09puOkn+zq6g8CUdc3YFAABcF4ptz2Kuy3302+DBg3Xs2DH7a//+/de6RAAAgBtWse1ZPP/Rb2FhYfb2Sz36zcPDQx4eHte8PgAAgJtBse1Z5NFvAAAAzufUnkUe/QYAAFC8OTUs8ug3AACA4s2pYZFHvwEAABRvxfacRQAAADgfYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcLidSQqKko2my3Pq2/fvs4uDQAA3KBcnV0ACm7dunXKzs62D//6669q1aqV7rvvPidWBQAAbmSExetImTJlHIZfe+01VaxYUTExMU6qCAAA3Oj4Gvo6lZmZqY8++kiPPvqobDabs8sBAAA3KMLidWr+/Pk6evSoEhMTnV0KAAC4gREWr1PTpk1TfHy8wsPDnV0KAAC4gXHO4nXojz/+0PLlyzV37lxnlwIAAG5w9Cxeh2bMmKHg4GDdddddzi4FAADc4AiL15mcnBzNmDFDCQkJcnWlYxgAAFxbhMXrzPLly7Vv3z49+uijzi4FAADcBOiaus60bt1axhhnlwEAAG4S9CwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACxxNXQhi3phobNLKHR7PZ1dAQAAcBZ6FgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgKViHRaTkpJks9kcXqGhoc4uCwAA4Kbh6uwCLqVmzZpavny5fdjFxcWJ1QAAANxcin1YdHV1pTcRAADASYr119CStHPnToWHhys6OloPPPCAfv/994tOn5GRofT0dIcXAAAArkyxDouNGzfWhx9+qCVLlui9995TWlqamjVrpsOHD1u+Z9SoUfL397e/IiIiirBiAACAG0uxDovx8fHq0qWLateurZYtW2rhwoWSpJkzZ1q+Z/DgwTp27Jj9tX///qIqFwAA4IZT7M9ZPJ+Pj49q166tnTt3Wk7j4eEhDw+PIqwKAADgxlWsexYvlJGRoW3btiksLMzZpQAAANwUinVYfPbZZ5WSkqI9e/boxx9/1L333qv09HQlJCQ4uzQAAICbQrH+GvrPP//Ugw8+qH/++UdlypRRkyZN9MMPPygyMtLZpQEAANwUinVYnD17trNLAAAAuKkV66+hAQAA4FyERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACw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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "\n",
    "# 2. Pull out the totals\n",
    "totals = df.loc['Total']\n",
    "\n",
    "# 3. Extract the four groups\n",
    "correctly = totals['Correctly rewritten?']\n",
    "\n",
    "qwen_before = totals['Qwen70+basicprompt BEFORE']\n",
    "qwen_after  = totals['Qwen70+basicprompt AFTER']\n",
    "\n",
    "dsr_before  = totals['DSReason+basicprompt BEFORE']\n",
    "dsr_after   = totals['DSReason+basicprompt AFTER']\n",
    "\n",
    "o3_before   = totals['GPT-o3+basicprompt BEFORE']\n",
    "o3_after    = totals['GPT-o3+basicprompt AFTER']\n",
    "\n",
    "species = (\"DS+Llama 70B\", \"deepseek-reasoner\", \"OpenAI o3\")\n",
    "penguin_means = {\n",
    "    'Before Rewriting': (int(qwen_before), int(dsr_before), int(o3_before)),\n",
    "    'After Rewriting': (int(qwen_after), int(dsr_after), int(o3_after)),\n",
    "\n",
    "}\n",
    "print(penguin_means)\n",
    "\n",
    "x = np.arange(len(species))  # the label locations\n",
    "width = 0.25  # the width of the bars\n",
    "multiplier = 0\n",
    "\n",
    "fig, ax = plt.subplots(layout='constrained')\n",
    "\n",
    "for attribute, measurement in penguin_means.items():\n",
    "    offset = width * multiplier\n",
    "    rects = ax.bar(x + offset, measurement, width, label=attribute)\n",
    "    ax.bar_label(rects, padding=2)\n",
    "    multiplier += 1\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('Count')\n",
    "ax.set_title('Correctness on top 30 rewritten math problems')\n",
    "ax.set_xticks(x + width / 2, species)\n",
    "ax.legend(loc='upper left', ncols=2)\n",
    "ax.set_ylim(0, 30)\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "qwen_before = totals['Qwen70+basicprompt BEFORE']\n",
    "qwen_after  = totals['Qwen70+basicprompt AFTER']\n",
    "\n",
    "dsr_before  = totals['DSReason+basicprompt BEFORE']\n",
    "dsr_after   = totals['DSReason+basicprompt AFTER']\n",
    "\n",
    "o3_before   = totals['GPT-o3+basicprompt BEFORE']\n",
    "o3_after    = totals['GPT-o3+basicprompt AFTER']\n",
    "\n",
    "qwen_same = 0\n",
    "qwen_more = 0 \n",
    "qwen_less = 0\n",
    "\n",
    "dsr_same = 0\n",
    "dsr_more = 0 \n",
    "dsr_less = 0\n",
    "\n",
    "o3_same = 0\n",
    "o3_more = 0 \n",
    "o3_less = 0\n",
    "df = df.fillna(0)\n",
    "df = df.replace(' ', 0)\n",
    "for index, row in df.iterrows():\n",
    "    if index == 'Total':\n",
    "        continue\n",
    " \n",
    "    if int(row['Qwen70+basicprompt BEFORE']) == int(row['Qwen70+basicprompt AFTER']):\n",
    "        qwen_same +=1\n",
    "    elif int(row['Qwen70+basicprompt BEFORE']) < int(row['Qwen70+basicprompt AFTER']):\n",
    "        qwen_more +=1\n",
    "    else:\n",
    "        qwen_less +=1\n",
    "    \n",
    "    if int(row['DSReason+basicprompt BEFORE']) == int(row['DSReason+basicprompt AFTER']):\n",
    "        dsr_same +=1\n",
    "    elif int(row['DSReason+basicprompt BEFORE']) < int(row['DSReason+basicprompt AFTER']):\n",
    "        dsr_more +=1\n",
    "    else:\n",
    "        dsr_less +=1\n",
    "\n",
    "    if int(row['GPT-o3+basicprompt BEFORE']) == int(row['GPT-o3+basicprompt AFTER']):\n",
    "        o3_same +=1\n",
    "    elif int(row['GPT-o3+basicprompt BEFORE']) < int(row['GPT-o3+basicprompt AFTER']):\n",
    "        o3_more +=1\n",
    "    else:\n",
    "        o3_less +=1\n",
    "\n",
    "\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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u+8+7d+/3z4/KSlJN954o8aPH28foTTGyGazaezYseratau8vb315ptvSpK+++473XzzzfLw8NB1112nIUOGKDc31768I0eO6PHHH1dwcLA8PDxUp04dzZ49W0uWLFHv3r2VmZkpm80mm82mpKSkYn/euXPnKjQ0VE888YRWrFhxwdsrPj5e3bp1s0/Hxsbqqaee0sCBAxUQEKCQkJBC9Vh9lgJff/21ateuLXd3d0VGRmrEiBEO74+MjNSbb76p+Ph4+fv7q0+fPvbR1dmzZysmJkbu7u7229kMHDhQVapUkbe3t5o0aaIlS5Y4LO+nn35Sy5Yt5eXlpUqVKqlDhw46fPiw4uPjlZqaqvfff9++bXfu3HnB26g4GFkEAOAK8Ndff2nevHl666235O3tXWh+waFeY4y6desmb29vpaamKjc3V/3791ePHj0cgsj27ds1ffp0ff3113JxcbG3Dx48WMnJyXrvvffk4uKi+fPn66GHHtIHH3ygW2+9VTt27NDjjz9u75ufn69OnTrp6NGj+uKLL3T99ddr06ZNcnFxUfPmzTVq1Ci99tpr2rJliyTJx8en2J+5Z8+eqly5sj777DO1bt1a1apVU69evdSrVy+Fh4eXYCtKkyZN0oABA/Tzzz9rxYoVio+PV4sWLdSuXbtzfhZJWrNmje677z4lJSWpR48eWr58ufr376/AwEDFx8fb1zF8+HC9+uqr+sc//iFJWrZsmU6cOKHk5GT961//UmBgoIKCgtS7d2/t3LlTU6dOVVhYmGbMmKGOHTtqw4YNqlGjhtatW6c2bdrokUce0QcffKAKFSpo8eLFysvL0/vvv6+tW7eqTp06ev311yVJ1157bYm2yfkQFgEAuAJs375dxhjVrFnznP0WLlyo9evXKz093R6oPv/8c9WuXVurVq1So0aNJJ05PPr5558XChgPPvigHnnkEfv0ww8/rJdeeklxcXGSpOuuu05vvPGGBg4cqMGDB2vhwoX65ZdflJaWpujoaHufAv7+/rLZbAoJCbngz1yhQgXdcccduuOOO5SZmamvvvpKn332mQYPHqzY2FjFxcXpnnvukaenZ7GXWa9ePQ0ePFiSVKNGDX300UdatGiR2rVrd97PMnLkSLVp00avvvqqJCk6OlqbNm3S8OHDHcJi69at9fzzz9unly1bptOnT2v06NGqX7++JGnHjh2aMmWK9u7dq7CwMEnS888/r3nz5mnChAkaOnSohg0bpoYNG2r06NH2ZdWuXdv+bzc3N3l5eZVo214IDkMDAHAFMMZI0nkfTZiWlqbw8HCHkbeYmBhVrFhRaWlp9raIiIgiR6IaNmzoML1mzRq9/vrr8vHxsb/69Oljf7b2unXrVLVqVXu4Kondu3c7LH/o0KGF+vj7++uxxx7T0qVLtXz5cqWnp6tXr16aP3/+Ba2rXr16DtOhoaE6cOCAJJ33s6SlpalFixYObS1atNC2bduUl5dnbzt7G0pngt3f17127VoZYxQdHe3w2VNTU7Vjxw57PW3atLmgz3cpMLIIAMAVoEaNGrLZbEpLS3M4D+9sBecenq+9qEPZRbXn5+dryJAhuvvuuwv19fDwuKBRPSthYWFat26dfTogIKBQn1OnTum7777T559/rnnz5qlBgwZ67rnnLjhMnX3Bjs1mU35+viSd97MUtW0LQvzfFbVtPT09Hd6bn58vFxcXrVmzxuE0AOl/h+pLY9uWBsIiAABXgICAAHXo0EH//Oc/9dRTTxUKJEeOHFHFihUVExOj3bt3a8+ePfbRxU2bNikzM1O1atW64PXedNNN2rJli6pXr17k/Hr16mnv3r3aunVrkSNybm5uDqNuRalQoUKRyzfGaNmyZfr88881ffp0+fj46KGHHtKwYcPOezi+JM73WWJiYrRs2TKHtuXLlys6OrpQ4DufBg0aKC8vTwcOHNCtt95qWc+iRYs0ZMiQIucXZ9uWBg5DAwBwhRg9erTy8vLUuHFjff3119q2bZvS0tL0wQcfqFmzZpKktm3bql69eurZs6fWrl2rX375Rb169VLLli2LPDx6Pq+99po+++wzJSUlaePGjUpLS9O0adPsF2+0bNlSt912m7p3766UlBSlp6fr+++/17x58ySduTr42LFjWrRokQ4ePKgTJ04Ue91ffPGFOnTooOPHj2v69OnavXu33n777UsSFIvzWZ577jktWrRIb7zxhrZu3apJkybpo48+cjg/sbiio6PVs2dP9erVS998843S09O1atUqvfPOO5o7d64kadCgQVq1apX69++v9evXa/PmzRozZowOHjwo6cy2/fnnn7Vz504dPHjQPkJa6sxVLjMz00gymZmZzi4FAFAGnDx50mzatMmcPHnS2aWUyH//+1+TkJBgIiIijJubm6lSpYq58847zeLFi+19du3aZe68807j7e1tfH19zb333msyMjLs8wcPHmzq169faNmSzIwZMwq1z5s3zzRv3tx4enoaPz8/07hxYzNu3Dj7/EOHDpnevXubwMBA4+HhYerUqWNmz55tn//EE0+YwMBAI8kMHjy42J/1jz/+uKi/33FxcaZr16726ZYtW5qnn37aoU/Xrl1NXFycffp8n+Xf//63iYmJMa6urqZatWpm+PDhDsuLiIgw7733nkPbhAkTjL+/f6H6cnJyzGuvvWYiIyONq6urCQkJMXfddZdZv369vc+SJUtM8+bNjbu7u6lYsaLp0KGDOXz4sDHGmC1btpimTZsaT09PI8mkp6cXWse5vu/FzUg2Y4o42H4VycrKkr+/vzIzM+Xn5+fscgAATnbq1Cmlp6crKiqqxDd7Bq4U5/q+FzcjcRgaAAAAlgiLKFXJyclq1KiRfH19FRQUpG7dutlvxFqg4E7zZ7+GDx/upKoBAIAVwiJKVWpqqhISErRy5UqlpKQoNzdX7du31/Hjx+199u3b5/AaP368bDabunfv7sTKAQBAUbh1DkpVwRVjBSZMmKCgoCCtWbNGt912myQVutP8t99+q1atWjncJR8AAJQNhEVcUpmZmZKKvsGqJO3fv19z5szRpEmTLmdZAACgmDgMjUvGGKMBAwbolltuUZ06dYrsM2nSJPn6+hb5ZAAAAOB8jCziknnyySe1fv36Qne7/7vx48erZ8+e3L4CAIAyirCISyIxMVGzZs3S0qVLVbVq1SL7/Pjjj9qyZYumTZt2masDAADFRVhEqTLGKDExUTNmzNCSJUsUFRVl2ffTTz/VzTffrPr161/GCgEAwIUgLKJUJSQkaPLkyfr222/l6+urjIwMSZK/v788PT3t/bKysvTVV19pxIgRzioVAApL8r/M68u8vOsrh5KSkjRz5kytW7fO2aVcsbjABaVqzJgxyszMVGxsrEJDQ+2vsw81T506VcYYPfDAA06qFACuPAcOHFDfvn1VrVo1ubu7KyQkRB06dNCKFSucXVqRIiMj7Q9e8PT0VM2aNTV8+HA580nD8fHx6tatm9PWfyViZBGlqri/AB5//HE9/vjjl7gaALi6dO/eXadPn9akSZN03XXXaf/+/Vq0aJH++usvZ5dm6fXXX1efPn106tQpLVy4UP36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s9m0c+fOYm+LuLg41alTR8OHD9e+ffsudFOWm+1UEoRFAACuYJMmTZK3t7d+/vlnDRs2TK+//rpSUlIkSfn5+erUqZOWL1+uL774Qps2bdLbb78tFxcXSdKaNWt033336f7779eGDRuUlJSkV199VRMnTnRYx/Dhw1WnTh2tWbNGr776qiTpxIkTSk5O1r/+9S9t3LhRQUFB6t27t3766SdNnTpV69ev17333quOHTtq27ZtkqR169apTZs2ql27tlasWKFly5apS5cuysvL0/vvv69mzZqpT58+2rdvn/bt26fw8PBib4fp06fr8ccf17Rp0xQeHq7bb79d06ZN06lTp8773vK0nUrCZowxl3QNTpaVlSV/f39lZmbKz8/P2eWUfUn+zq7g4iRlOrsCAGXcqVOnlJ6erqioKHl4eDjMK+sXuMTHx+vIkSOaOXOmpDMji3l5efrxxx/tfRo3bqzWrVvr7bff1oIFC9SpUyelpaUpOjq60PJ69uypP//8UwsWLLC3DRw4UHPmzNHGjRslnRkxa9CggWbMmGHvM3HiRPXu3Vvr1q1T/fr1JUk7duxQjRo1tHfvXoWFhdn7tm3bVo0bN9bQoUP14IMPavfu3Vq2bFmRny82NlY33nijRo0adUHb5WxpaWmaNGmSvvzySx07dkw9evRQfHy8mjZtWmT/q3k7nev7XtyMxMgiAABXsHr16jlMh4aG6sCBA5LOjFBVrVq1yAAknQlVLVq0cGhr0aKFtm3bpry8PHtbw4YNC73Xzc3NYd1r166VMUbR0dHy8fGxv1JTU7Vjxw57PW3atCnZB/1/Q4cOdVh+Uecq1qpVS2+//bZ27dqlQYMGafz48erYsaPlMq/G7VSauHUOAABXMFdXV4dpm81mv4jC09PznO81xshmsxVqO5u3t3ehNk9PT4f35ufny8XFRWvWrLEfvi3g4+NTrHqK44knntB9991nn/776FyBPXv26Msvv9Tnn3+u9PR03Xvvverdu7flMq/G7VSaCIsAAFyl6tWrp71792rr1q1FjprFxMQUOtS5fPlyRUdHFwoy59OgQQPl5eXpwIEDuvXWWy3rWbRokYYMGVLkfDc3N4eRuqIEBAQoICCgUPvRo0f19ddf6/PPP9eSJUvUvHlzPfvss7rvvvvOexra1bidShOHoQEAuEq1bNlSt912m7p3766U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4eYffvihWMs5fvy46tevr969e6t79+5F9unYsaMmTJhgn3Zzc7uwYgEAAFBiJQqLBecrFjh9+rTWrVun3377TXFxccVeTqdOndSpU6dz9nF3d1dISEixl5mdna3s7Gz7dFZWVrHfCwAAAEclCovvvfdeke1JSUk6duzYRRV0tiVLligoKEgVK1ZUy5Yt9dZbbykoKMiyf3JysoYMGVKqNQAAAJRXpXrO4kMPPVSqz4Xu1KmTvvzyS/3www8aMWKEVq1apdatWzuMHJ5t0KBByszMtL/27NlTavUAAACUNyUaWbSyYsUKeXh4lNryevToYf93nTp11LBhQ0VERGjOnDm6++67i3yPu7u73N3dS60GAACA8qxEYfHsoGaM0b59+7R69Wq9+uqrpVJYUUJDQxUREaFt27ZdsnUAAADgf0oUFv39/R2mr7nmGt1www16/fXX1b59+1IprCiHDh3Snj17FBoaesnWAQAAgP8pUVj8+61sLsaxY8e0fft2+3R6errWrVungIAABQQEKCkpSd27d1doaKh27typl19+WZUrV9Zdd91VKusHAADAuV3UOYtr1qxRWlqabDabYmJi1KBBgwt6/+rVq9WqVSv79IABAyRJcXFxGjNmjDZs2KDPPvtMR44cUWhoqFq1aqVp06bJ19f3YsoGAABAMZUoLB44cED333+/lixZoooVK8oYo8zMTLVq1UpTp07VtddeW6zlxMbGyhhjOX/+/PklKQ8AAAClpES3zklMTFRWVpY2btyov/76S4cPH9Zvv/2mrKwsPfXUU6VdIwAAAJykRCOL8+bN08KFC1WrVi17W0xMjP75z39e0gtcAAAAcHmVaGQxPz9frq6uhdpdXV2Vn59/0UUBAACgbChRWGzdurWefvpp/fe//7W3/fHHH3r22WfVpk2bUisOAAAAzlWisPjRRx/p6NGjioyM1PXXX6/q1asrKipKR48e1YcffljaNQIAAMBJSnTOYnh4uNauXauUlBRt3rxZxhjFxMSobdu2pV0fAAAAnOiCRhZ/+OEHxcTEKCsrS5LUrl07JSYm6qmnnlKjRo1Uu3Zt/fjjj5ekUAAAAFx+FxQWR40apT59+sjPz6/QPH9/f/Xt21cjR44steIAAADgXBcUFv/zn/+oY8eOlvPbt2+vNWvWXHRRAAAAKBsuKCzu37+/yFvmFKhQoYL+/PPPiy4KAAAAZcMFhcUqVapow4YNlvPXr1+v0NDQiy4KAAAAZcMFhcXbb79dr732mk6dOlVo3smTJzV48GB17ty51IoDAACAc13QrXP+8Y9/6JtvvlF0dLSefPJJ3XDDDbLZbEpLS9M///lP5eXl6ZVXXrlUtQIAAOAyu6CwGBwcrOXLl6tfv34aNGiQjDGSJJvNpg4dOmj06NEKDg6+JIUCAADg8rvgm3JHRERo7ty5Onz4sLZv3y5jjGrUqKFKlSpdivoAAADgRCV6goskVapUSY0aNSrNWgAAAFDGlOjZ0AAAACgfCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALBEWAQAAYImwCAAAAEuERQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALDk1LC5dulRdunRRWFiYbDabZs6c6TDfGKOkpCSFhYXJ09NTsbGx2rhxo3OKBQAAKIecGhaPHz+u+vXr66OPPipy/rBhwzRy5Eh99NFHWrVqlUJCQtSuXTsdPXr0MlcKAABQPlVw5so7deqkTp06FTnPGKNRo0bplVde0d133y1JmjRpkoKDgzV58mT17dv3cpYKAABQLpXZcxbT09OVkZGh9u3b29vc3d3VsmVLLV++3PJ92dnZysrKcngBAACgZMpsWMzIyJAkBQcHO7QHBwfb5xUlOTlZ/v7+9ld4ePglrRMAAOBqVmbDYgGbzeYwbYwp1PZ3gwYNUmZmpv21Z8+eS10iAADAVcup5yyeS0hIiKQzI4yhoaH29gMHDhQabfw7d3d3ubu7X/L6AAAAyoMyO7IYFRWlkJAQpaSk2NtycnKUmpqq5s2bO7EyAACA8sOpI4vHjh3T9u3b7dPp6elat26dAgICVK1aNT3zzDMaOnSoatSooRo1amjo0KHy8vLSgw8+6MSqAQAAyg+nhsXVq1erVatW9ukBAwZIkuLi4jRx4kQNHDhQJ0+eVP/+/XX48GE1adJECxYskK+vr7NKBgAAKFecGhZjY2NljLGcb7PZlJSUpKSkpMtXFAAAAOzK7DmLAAAAcD7CIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgDgvP744w899NBDCgwMlJeXl2688UatWbPG2WUBl0153gcqOLsAAEDZdvjwYbVo0UKtWrXS999/r6CgIO3YsUMVK1Z0dmnAZVHe9wHCIgDgnN555x2Fh4drwoQJ9rbIyEjnFQRcZuV9H+AwNADgnGbNmqWGDRvq3nvvVVBQkBo0aKBPPvnE2WUBl0153wcIiwCAc/r99981ZswY1ahRQ/Pnz9cTTzyhp556Sp999pmzSwMui/K+D3AYGgBwTvn5+WrYsKGGDh0qSWrQoIE2btyoMWPGqFevXk6uDrj0yvs+wMgiAOCcQkNDFRMT49BWq1Yt7d6920kVAZdXed8HCIsAgHNq0aKFtmzZ4tC2detWRUREOKki4PIq7/sAYREAcE7PPvusVq5cqaFDh2r79u2aPHmyxo0bp4SEBGeXBlwW5X0fICwCAM6pUaNGmjFjhqZMmaI6derojTfe0KhRo9SzZ09nlwZcFuV9H+ACFwDAeXXu3FmdO3d2dhmA05TnfYCRRQAAAFgiLAIAAMASYREAAACWCIsAAACwRFgEAACAJcIiAAAALHHrHAC4ytSdVNfZJVyUDXEbnF0CrnDsA6WLkUUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYKtNhMSkpSTabzeEVEhLi7LIAAADKjTL/uL/atWtr4cKF9mkXFxcnVgMAAFC+lPmwWKFCBUYTAQAAnKRMH4aWpG3btiksLExRUVG6//779fvvv5+zf3Z2trKyshxeAAAAKJkyHRabNGmizz77TPPnz9cnn3yijIwMNW/eXIcOHbJ8T3Jysvz9/e2v8PDwy1gxAADA1aVMh8VOnTqpe/fuqlu3rtq2bas5c+ZIkiZNmmT5nkGDBikzM9P+2rNnz+UqFwAA4KpT5s9Z/Dtvb2/VrVtX27Zts+zj7u4ud3f3y1gVAADA1atMjyyeLTs7W2lpaQoNDXV2KQAAAOVCmQ6Lzz//vFJTU5Wenq6ff/5Z99xzj7KyshQXF+fs0gAAAMqFMn0Yeu/evXrggQd08OBBXXvttWratKlWrlypiIgIZ5cGAABQLpTpsDh16lRnlwAAAFCulenD0AAAAHAuwiIAAAAsERYBAABgibAIAAAAS4RFAAAAWCIsAucxZswY1atXT35+fvLz81OzZs30/fffO7ssAAAuC8IicB5Vq1bV22+/rdWrV2v16tVq3bq1unbtqo0bNzq7NAAALrkyfZ9FoCzo0qWLw/Rbb72lMWPGaOXKlapdu7aTqgIA4PIgLAIXIC8vT1999ZWOHz+uZs2aObscAAAuOcIiUAwbNmxQs2bNdOrUKfn4+GjGjBmKiYlxdlkAAFxynLMIFMMNN9ygdevWaeXKlerXr5/i4uK0adMmZ5cFAMAlx8giUAxubm6qXr26JKlhw4ZatWqV3n//fX388cdOrgwAgEuLkUWgBIwxys7OdnYZAABccowsAufx8ssvq1OnTgoPD9fRo0c1depULVmyRPPmzXN2aQAAXHKEReA89u/fr4cfflj79u2Tv7+/6tWrp3nz5qldu3bOLg0AgEuOsAicx6effursEgAAcBrOWQQAAIAlwiIAAAAsERYBAABgibAIoMxLTk5Wo0aN5Ovrq6CgIHXr1k1btmxxdlkAUC4QFgGUeampqUpISNDKlSuVkpKi3NxctW/fXsePH3d2aQBw1eNqaABl3tn3tJwwYYKCgoK0Zs0a3XbbbU6qCgDKB8Iirip1J9V1dgkXbUPcBmeXUOZlZmZKkgICApxcCQBc/TgMDeCKYozRgAEDdMstt6hOnTrOLgcArnqMLAK4ojz55JNav369li1b5uxSAKBcICwCuGIkJiZq1qxZWrp0qapWrerscgCgXCAsAijzjDFKTEzUjBkztGTJEkVFRTm7JAAoNwiLAMq8hIQETZ48Wd9++618fX2VkZEhSfL395enp6eTqwOAqxsXuAAo88aMGaPMzEzFxsYqNDTU/po2bZqzSwOAqx4jiwDKPGOMs0sAgHKLkUUAAABYIiwCAADAEmERAAAAlgiLAAAAsERYBACgjFu6dKm6dOmisLAw2Ww2zZw509kloRwhLAIAUMYdP35c9evX10cffeTsUlAOcescAKUq8qU5zi7houz0cHYFQGGdOnVSp06dnF0GyilGFgEAAGCJsAgAAABLhEUAAABYIiwCAADAEmERAAAAlrgaGgCAMu7YsWPavn27fTo9PV3r1q1TQECAqlWr5sTKUB4QFgEAKONWr16tVq1a2acHDBggSYqLi9PEiROdVBXKC8IiAABlXGxsrIwxzi4D5RTnLAIAAMASYREAAACWCIsAAACwRFi8QowePVpRUVHy8PDQzTffrB9//NHZJQEAgHKAsHgFmDZtmp555hm98sor+vXXX3XrrbeqU6dO2r17t7NLAwAAVzmuhr4CjBw5Uo8++qgee+wxSdKoUaM0f/58jRkzRsnJyU6uDgDwd5EvzXF2CRdlp4ezK0BZw8hiGZeTk6M1a9aoffv2Du3t27fX8uXLnVQVAAAoLwiLZdzBgweVl5en4OBgh/bg4GBlZGQ4qSoAAFBeEBavEDabzWHaGFOoDQAAoLQRFsu4ypUry8XFpdAo4oEDBwqNNgIAAJQ2wmIZ5+bmpptvvlkpKSkO7SkpKWrevLmTqgIAAOUFV0NfAQYMGKCHH35YDRs2VLNmzTRu3Djt3r1bTzzxhLNLAwAAVznC4hWgR48eOnTokF5//XXt27dPderU0dy5cxUREeHs0gAAwFWOsHiF6N+/v/r37+/sMgAAQDnDOYsAAACwdEWERZ6LDAAA4BxlPizyXGQAAADnKfNh8e/PRa5Vq5ZGjRql8PBwjRkzxtmlAQAAXPXK9AUuBc9Ffumllxzaz/Vc5OzsbGVnZ9unMzMzJUlZWVmXrtCrSbZxdgUXJe9knrNLuGhX+nc1P/uEs0u4KFm2K3sfkK78/YB9wLnYB5zvcu0DBesx5tw/8zIdFkvyXOTk5GQNGTKkUHt4ePglqRFlTZqzC7ho/v38nV1CuXZ1bP0rez9gH3Cuq2Prsw9ciKNHj8rf33qdZTosFriQ5yIPGjRIAwYMsE/n5+frr7/+UmBgIM9SdrKsrCyFh4drz5498vPzc3Y5wGXHPgCwH5QlxhgdPXpUYWFh5+xXpsNiSZ6L7O7uLnd3d4e2ihUrXqoSUQJ+fn78gkC5xj4AsB+UFecaUSxQpi9w4bnIAAAAzlWmRxYlnosMAADgTGU+LPJc5KuHu7u7Bg8eXOg0AaC8YB8A2A+uRDZzvuulAQAAUG6V6XMWAQAA4FyERQAAAFgiLAIAAMASYREAAACWCIsosdjYWD3zzDPOLgNXgavxuxQZGalRo0Y5uwwAuGiExTIuPj5eNptNNptNrq6uCg4OVrt27TR+/Hjl5+c79P3111/VuXNnBQUFycPDQ5GRkerRo4cOHjxYonVPnDjxin36TWRkpH27/f2VkJBg72OMUVJSksLCwuTp6anY2Fht3LjRcjkuLi4KCwvTo48+qsOHD1/ujwQAF2XPnj169NFHFRYWJjc3N0VEROjpp5/WoUOHnFrX8uXL5eLioo4dOxaat3PnTtlsNq1bt67Ey9+yZYtatWql4OBgeXh46LrrrtM//vEPnT59+iKqLl8Ii1eAjh07at++fdq5c6e+//57tWrVSk8//bQ6d+6s3NxcSWcegdi2bVtVrlxZ8+fPV1pamsaPH6/Q0FCdOHGiyOUuWbJEkZGRl/GTXD6rVq3Svn377K+CpwDde++99j7Dhg3TyJEj9dFHH2nVqlUKCQlRu3btdPToUYdlFdzjc/fu3fryyy+1dOlSPfXUU5f186B8ysnJcXYJl0xeXl6h//Di0vn999/VsGFDbd26VVOmTNH27ds1duxYLVq0SM2aNdNff/3ltNrGjx+vxMRELVu2TLt37y715bu6uqpXr15asGCBtmzZolGjRumTTz7R4MGDS31dVy2DMi0uLs507dq1UPuiRYuMJPPJJ58YY4yZMWOGqVChgjl9+nSxl7148WITERFhOX/ChAnG39/fcn7Lli3N008/bZ/+/PPPzc0332x8fHxMcHCweeCBB8z+/fsd1ifJzJs3z9x4443Gw8PDtGrVyuzfv9/MnTvX1KxZ0/j6+pr777/fHD9+3P6+77//3rRo0cL4+/ubgIAAc8cdd5jt27cX+3MaY8zTTz9trr/+epOfn2+MMSY/P9+EhISYt99+297n1KlTxt/f34wdO9beFhERYd577z2HZb3++usmJibmgtaP/zl27Jh5+OGHjbe3twkJCTHvvvuuw3cpOzvbvPDCCyYsLMx4eXmZxo0bm8WLFzss46effjK33nqr8fDwMFWrVjWJiYnm2LFj9vkRERHm9ddfNw888IDx9vY2oaGh5oMPPnBYxuDBg014eLhxc3MzoaGhJjEx0T6vtGr4+3dn/Pjxxs/PzyxYsMBy20RERJg33njDxMXFGT8/P9OrV69iret8+95ff/1lHnzwQVO5cmXj4eFhqlevbsaPH2+fv379etOqVSvj4eFhAgICTJ8+fczRo0ft8wt+Dw0fPtyEhISYgIAA079/f5OTk1PsbVbw++S7774ztWrVMi4uLub333+33BYoXR07djRVq1Y1J06ccGjft2+f8fLyMk888YS9rTj7z5EjR0yfPn3Mtddea3x9fU2rVq3MunXr7PMHDx5s6tevbz777DMTERFh/Pz8TI8ePUxWVpbDco4dO2Z8fX3N5s2bTY8ePcyQIUMc5qenpxtJ5tdff7X8bH/99Zd5+OGHTcWKFY2np6fp2LGj2bp16zm3x7PPPmtuueWWc/bB/xAWyzirsGiMMfXr1zedOnUyxhizYsUKI8lMnz7dHojOp7TD4qeffmrmzp1rduzYYVasWGGaNm1qr69gfZJM06ZNzbJly8zatWtN9erVTcuWLU379u3N2rVrzdKlS01gYKBDiPv3v/9tvv76a7N161bz66+/mi5dupi6deuavLy8Yn3O7OxsExgYaN566y17244dO4wks3btWoe+d955p/0PtDGF/+Dv3bvXNG7c2PTu3btY60Zh/fr1M1WrVjULFiww69evN507dzY+Pj7279KDDz5omjdvbpYuXWq2b99uhg8fbtzd3e2//NevX298fHzMe++9Z7Zu3Wp++ukn06BBAxMfH29fR0REhPH19TXJyclmy5Yt5oMPPjAuLi72oPbVV18ZPz8/M3fuXLNr1y7z888/m3HjxtnfX1o1FHx3hg8fbgICAsyKFSvOuW0K/qgOHz7cbNu2zWzbtq1Y6zrfvpeQkGBuvPFGs2rVKpOenm5SUlLMrFmzjDHGHD9+3ISFhZm7777bbNiwwSxatMhERUWZuLg4+/sLwusTTzxh0tLSzHfffWe8vLwuaJtNmDDBuLq6mubNm5uffvrJbN682SHw4tI5dOiQsdlsZujQoUXO79Onj6lUqZL9b8f59p/8/HzTokUL06VLF7Nq1SqzdetW89xzz5nAwEBz6NAhY8yZsOjj42P/Xi1dutSEhISYl19+2WHdn376qWnYsKExxpjvvvvOREZGOvwNK05YvPPOO02tWrXM0qVLzbp160yHDh1M9erVHf4z83fbtm0ztWrVMq+88krxNiAIi2XducJijx49TK1atezTL7/8sqlQoYIJCAgwHTt2NMOGDTMZGRmWyy7tsHi2X375xUiyj1AUhMWFCxfa+yQnJxtJZseOHfa2vn37mg4dOlgu98CBA0aS2bBhg2Wfv5s2bZpxcXExf/zxh73tp59+MpIc2ow580uzffv29umIiAjj5uZmvL29jYeHh5FkmjRpYg4fPlysdcPR0aNHjZubm5k6daq97dChQ8bT09M8/fTTZvv27cZmsxX6ubRp08YMGjTIGGPMww8/bB5//HGH+T/++KO55pprzMmTJ40xZ35uHTt2dOjTo0cPe4AaMWKEiY6OLvKPSWnW8N5775mXXnrJhIaGmvXr1593+0RERJhu3bo5tBVnXWc7e9/r0qWL5X9wxo0bZypVquQQ3ObMmWOuueYa+++PuLg4ExERYXJzc+197r33XtOjRw9jTPG22YQJE4wkh9EnXB4rV640ksyMGTOKnD9y5EgjyT4afb79Z9GiRcbPz8+cOnXKoc/1119vPv74Y2PMmbDo5eXlMJL4wgsvmCZNmji8p3nz5mbUqFHGGGNOnz5tKleubFJSUuzzzxcWt27daiSZn376yd528OBB4+npaaZPn+7Qt1mzZsbd3d1IMo8//nixBxxgDOcsXsGMMbLZbPbpt956SxkZGRo7dqxiYmI0duxY1axZUxs2bLD38fHxsb86deqk3bt3F2orqV9//VVdu3ZVRESEfH19FRsbK0mFzkGpV6+e/d/BwcHy8vLSdddd59B24MAB+/SOHTv04IMP6rrrrpOfn5+ioqKKXK6VTz/9VJ06dVJYWFiheX/fflLhbSpJL7zwgtatW6f169dr0aJFkqQ77rhDeXl5xVo//mfHjh3KyclRs2bN7G0BAQG64YYbJElr166VMUbR0dEO38vU1FTt2LFDkrRmzRpNnDjRYX6HDh2Un5+v9PR0+3L/vo6C6bS0NElnzl09efKkrrvuOvXp00czZsywn/9bmjWMGDFCH3/8sZYtW6a6deva27/88kuH9/7444/2eQ0bNnSouzjrOt++169fP02dOlU33nijBg4cqOXLl9uXn5aWpvr168vb29ve1qJFC+Xn52vLli32ttq1a8vFxcU+HRoaat9Pi7PNJMnNzc1h/0fZYP7/qb9//913rv1nzZo1OnbsmAIDAx1+3unp6Q4/78jISPn6+tqn//6dkc5cePLLL7/o/vvvlyRVqFBBPXr00Pjx44tde1pamipUqKAmTZrY2wIDA3XDDTfY6y0wbdo0rV27VpMnT9acOXP07rvvFns95V0FZxeAkktLS7MHpwKBgYG69957de+99yo5OVkNGjTQu+++q0mTJkmSwxVlP//8s1588UUtWbLE3ubp6VmiWo4fP6727durffv2+uKLL3Tttddq9+7d6tChQ6GT9F1dXe3/LrjK++9sNpvDie9dunRReHi4PvnkE4WFhSk/P1916tQp1sn/u3bt0sKFC/XNN984tIeEhEiSMjIyFBoaam8/cOCAgoODHfpWrlxZ1atXlyTVqFFDo0aNUrNmzbR48WK1bdv2vDXgf8x5HkWfn58vFxcXrVmzxiGYSGf+o1PQp2/fvkVeZFStWrVzLr/gj2F4eLi2bNmilJQULVy4UP3799fw4cOVmppaqjXceuutmjNnjqZPn66XXnrJ3n7nnXc6/HGrUqWK/d9/D23FWVdx9r1OnTpp165dmjNnjhYuXKg2bdooISFB7777bpH/QTp7e0k6535anG0mnfn9YrUuXDrVq1eXzWbTpk2b1K1bt0LzN2/erEqVKqly5crnXE7Bzy4/P1+hoaEOfzsK/P0OGuf73f7pp58qNzfX4ftvjJGrq6sOHz6sSpUqnfezWf1OKep7HR4eLkmKiYlRXl6eHn/8cT333HOFvrMojLB4hfrhhx+0YcMGPfvss5Z93NzcdP311+v48eP2toLQI0l79+5VhQoVHNpKavPmzTp48KDefvtt+w65evXqi17uoUOHlJaWpo8//li33nqrJGnZsmXFfv+ECRMUFBSkO+64w6E9KipKISEhSklJUYMGDSSdufI0NTVV77zzzjmXWfCL5eTJkxfyUaAz3z9XV1etXLnSHqoOHz6srVu3qmXLlmrQoIHy8vJ04MAB+8/7bDfddJM2btx43u/typUrC03XrFnTPu3p6ak777xTd955pxISEuyj8KVZQ+PGjZWYmKgOHTrIxcVFL7zwgiTJ19fXYcTlXM63rg0bNhRr37v22msVHx+v+Ph43XrrrXrhhRf07rvvKiYmRpMmTdLx48ftQfWnn37SNddco+jo6GLVWJxtBucJDAxUu3btNHr0aD377LMOgwIZGRn68ssv1atXL4dwda7956abblJGRoYqVKhQ4jtq5Obm6rPPPtOIESPUvn17h3ndu3fXl19+qSeffPK8y4mJiVFubq5+/vlnNW/eXNKZvxtbt25VrVq1LN9njNHp06fP+x9YnEFYvAJkZ2crIyNDeXl52r9/v+bNm6fk5GR17txZvXr1kiTNnj1bU6dO1f3336/o6GgZY/Tdd99p7ty5mjBhQonXnZeXV+j+Vm5uboqJiXFoq1atmtzc3PThhx/qiSee0G+//aY33nijxOstUKlSJQUGBmrcuHEKDQ3V7t27HUZoziU/P18TJkxQXFycKlRw/KrbbDY988wzGjp0qGrUqKEaNWpo6NCh8vLy0oMPPujQ9+jRo8rIyJAxRnv27NHAgQNVuXJl+y8mFJ+Pj48effRRvfDCCwoMDFRwcLBeeeUVXXPNmTNioqOj1bNnT/Xq1UsjRoxQgwYNdPDgQf3www+qW7eubr/9dr344otq2rSpEhIS1KdPH3l7eystLU0pKSn68MMP7ev66aefNGzYMHXr1k0pKSn66quvNGfOHEln7iGal5enJk2ayMvLS59//rk8PT0VERGhwMDAUqtBOnP47vvvv1fHjh1VoUKFc/4HryjnW1dx9r3XXntNN998s2rXrq3s7GzNnj3b/oe0Z8+eGjx4sOLi4pSUlKQ///xTiYmJevjhhwuNslspzs8NzvXRRx+pefPm6tChg958801FRUVp48aNeuGFF1SlShW99dZbDv3Ptf+0bdtWzZo1U7du3fTOO+/ohhtu0H//+1/NnTtX3bp1K3QqRVFmz56tw4cP69FHH5W/v7/DvHvuuUeffvppscJijRo11LVrV/Xp00cff/yxfH199dJLL6lKlSrq2rWrpDOnfbi6uqpu3bpyd3fXmjVrNGjQIPXo0aPQ3wZYcMJ5krgAcXFxRpKRZCpUqGCuvfZa07ZtWzN+/HiHk3N37Nhh+vTpY6Kjo42np6epWLGiadSokZkwYYLlsotzgUvBuv/+KnjP2Re4TJ482URGRhp3d3fTrFkzM2vWLIcTkwsucPn7xSFFXURTcMuFAikpKaZWrVrG3d3d1KtXzyxZsuScJ2sXmD9/vpFktmzZUuT8/Px8M3jwYBMSEmLc3d3NbbfdVuiimYiICIfPfu2115rbb7/9nFfm4dyOHj1qHnroIePl5WWCg4PNsGHDHL5LOTk55rXXXjORkZHG1dXVhISEmLvuusvhApFffvnFtGvXzvj4+Bhvb29Tr149h6vdIyIizJAhQ8x9991nX0/BSfTGnLnVVJMmTYyfn5/x9vY2TZs2dbjwqrRq+PuV9Kmpqcbb29u8//77ltumqFs1FWdd59v33njjDVOrVi3j6elpAgICTNeuXR1uW1PcW+f83dNPP21atmxZ7G12vgvmcOnt3LnTxMfHm5CQEOPq6mrCw8NNYmKiOXjwoEO/8+0/xhiTlZVlEhMTTVhYmH1ZPXv2NLt37zbGFP49bowx7733nv3vR+fOnc3tt99eZJ1r1qwxksyaNWsu6NY5/v7+xtPT03To0MHh1jlTp041N910k33/iYmJMUOHDrW8QAyF2YxhDBbA1SUyMlLPPPPMVfcIQeByYP/B2bgaGgAAAJYIiwAAALDEYWgAAABYYmQRAAAAlgiLAAAAsERYBAAAgCXCIgAAACwRFgEAAGCJsAgAAABLhEUAAABYIiwCAADA0v8BSsgNWNB6WlAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "species = (\"DS+Llama 70B\", \"deepseek-reasoner\", \"OpenAI o3\")\n",
    "penguin_means = {\n",
    "    'Correct -> incorrect': (int(qwen_less), int(dsr_less), int(o3_less)),\n",
    "    'Same Result': (int(qwen_same), int(dsr_same), int(o3_same)),\n",
    "    'Incorrect -> correct': (int(qwen_more), int(dsr_more), int(o3_more))\n",
    "\n",
    "}\n",
    "\n",
    "x = np.arange(len(species))  # the label locations\n",
    "width = 0.25  # the width of the bars\n",
    "multiplier = 0\n",
    "\n",
    "fig, ax = plt.subplots(layout='constrained')\n",
    "\n",
    "for attribute, measurement in penguin_means.items():\n",
    "    offset = width * multiplier\n",
    "    rects = ax.bar(x + offset, measurement, width, label=attribute)\n",
    "    ax.bar_label(rects, padding=3)\n",
    "    multiplier += 1\n",
    "\n",
    "# Add some text for labels, title and custom x-axis tick labels, etc.\n",
    "ax.set_ylabel('Count')\n",
    "ax.set_title('Change in result after rewriting')\n",
    "ax.set_xticks(x + width, species)\n",
    "ax.legend(loc='upper right', ncols=1)\n",
    "ax.set_ylim(0, 30)\n",
    "\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bt",
   "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"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
