{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "from utils.utils import count_tokens\n",
    "from utils.utils import read_jsonl\n",
    "\n",
    "def record_tokens_accuracy(model_name, dataset_list, hard_level, method_list):\n",
    "    tokens_dict = {}\n",
    "    accuracy_dict = {}\n",
    "    for method in method_list:\n",
    "        total_tokens = 0\n",
    "        total_problems = 0\n",
    "        total_correct_numbs = 0\n",
    "        for dataset in dataset_list: \n",
    "            tokens = 0\n",
    "            if 'gpt' in model_name:\n",
    "                data_path = f'results/gpt/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "            else:\n",
    "                data_path = f'results/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "            data = read_jsonl(data_path)\n",
    "            \n",
    "            problems = len(data)\n",
    "            correct_numbs = 0\n",
    "            error_numbs = 0\n",
    "\n",
    "            for row in data:\n",
    "                correct = row['correct']\n",
    "                if correct:\n",
    "                    correct_numbs += 1\n",
    "                try:\n",
    "                    if method in ['cot', 'pal', 'metamath']:\n",
    "                        # print(row['reasoning_path'])\n",
    "                        answer_tokens = count_tokens(row['reasoning_path'])\n",
    "                        # print(answer_tokens)\n",
    "                        \n",
    "                    elif method in ['nlcode', 'codenl']:\n",
    "                        answer_tokens = count_tokens(row['reasoning_path_1']) + count_tokens(row['reasoning_path_2'])\n",
    "\n",
    "                    tokens += answer_tokens\n",
    "                except Exception as e:\n",
    "                    print(e)\n",
    "                    error_numbs += 1\n",
    "                    print(f\"Error in model {model_name} on dataset {dataset} with method {method}\")\n",
    "            # print(f\"Error numbs for model {model_name} on dataset {dataset} is {error_numbs}\")\n",
    "            problems -= error_numbs # remove the error problems\n",
    "            # print(f\"Average tokens for model {model_name} on dataset {dataset} is {average_tokens}\")\n",
    "            total_tokens += tokens\n",
    "            total_problems += problems\n",
    "            total_correct_numbs += correct_numbs\n",
    "\n",
    "        total_average_tokens = total_tokens / total_problems\n",
    "        tokens_dict[method] = total_average_tokens\n",
    "        # accuracy = correct_numbs / total_problems\n",
    "        accuracy = total_correct_numbs / total_problems\n",
    "        accuracy_dict[method] = accuracy\n",
    "        print(f\"Total average tokens for method {method} is {total_average_tokens}\")\n",
    "    return tokens_dict, accuracy_dict\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total average tokens for method cot is 840.6175024582104\n",
      "Total average tokens for method pal is 298.25860373647987\n",
      "Total average tokens for method codenl is 1188.0265486725664\n",
      "Total average tokens for method nlcode is 1110.0688298918387\n",
      "Total average tokens for method cot is 751.5496558505408\n",
      "Total average tokens for method pal is 342.49950835791543\n",
      "Total average tokens for method codenl is 1005.4886922320551\n",
      "Total average tokens for method nlcode is 935.9026548672566\n",
      "Total average tokens for method cot is 698.306784660767\n",
      "Total average tokens for method pal is 254.0560471976401\n",
      "Total average tokens for method codenl is 856.5634218289085\n",
      "Total average tokens for method nlcode is 839.9419862340217\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Computation budget vs Accuracy')"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model_name_list = ['meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo', 'meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo',\n",
    "                   'gpt-4o-mini']\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "def plot_token_accuracy(model_name, dataset_list, hard_level, method_list, color, degree=2):\n",
    "    tokens_dict, accuracy_dict = record_tokens_accuracy(model_name, dataset_list, hard_level, method_list)\n",
    "    # the x axis is the tokens, the y axis is the accuracy\n",
    "    token_list = []\n",
    "    accuracy_list = []\n",
    "    for method in method_list:\n",
    "        tokens = tokens_dict[method]\n",
    "        accuracy = accuracy_dict[method]\n",
    "        plt.scatter(tokens, accuracy, color=color)\n",
    "        plt.text(tokens, accuracy, f\"{method}\", fontsize=8, ha='right', va='bottom', color=color)\n",
    "        token_list.append(tokens)\n",
    "        accuracy_list.append(accuracy)\n",
    "    # for i in range(len(tokens)):\n",
    "    #     plt.text(tokens[i], accuracy[i], f\"{method}\", fontsize=8, ha='right', va='bottom', color=color)\n",
    "    # print(tokens)\n",
    "    # Fit a line and plot it with the same color\n",
    "    # Combine all tokens and accuracies for line fitting\n",
    "    # Combine all tokens and accuracies\n",
    "    token_list = np.array(token_list)\n",
    "    accuracy_list = np.array(accuracy_list)\n",
    "    \n",
    "    # Fit a higher-order polynomial\n",
    "    poly_fit = np.poly1d(np.polyfit(token_list, accuracy_list, degree))\n",
    "    sorted_tokens = np.sort(token_list)\n",
    "    if 'Meta-Llama-3.1-8B' in model_name:\n",
    "        label = 'llama-8B'\n",
    "    elif 'Meta-Llama-3.1-70B' in model_name:\n",
    "        label = 'llama-70B'\n",
    "    elif 'gpt-4o-mini' in model_name:\n",
    "        label = 'gpt-4o-mini'\n",
    "    plt.plot(\n",
    "        sorted_tokens,\n",
    "        poly_fit(sorted_tokens),\n",
    "        # label=f\"{model_name} {degree}-Degree Fit\",\n",
    "        label=f\"{label}\",\n",
    "        color=color\n",
    "    )\n",
    "\n",
    "fig = plt.figure()\n",
    "color_palette = ['blue', 'green', 'red', 'purple', 'orange']  # Define a palette of colors\n",
    "\n",
    "dataset_list = ['counting & probability', 'geometry', 'number theory', 'intermediate algebra','precalculus', 'prealgebra']\n",
    "hard_level = \"Level 5\"\n",
    "method_list = ['cot', 'pal', 'codenl', 'nlcode',]\n",
    "# for model in model_name_list:\n",
    "for i, model in enumerate(model_name_list):\n",
    "    # plot_token_accuracy(model, dataset_list, hard_level, method_list)\n",
    "    plot_token_accuracy(model, dataset_list, hard_level, method_list, color_palette[i])\n",
    "plt.legend()\n",
    "plt.xlabel('Average Tokens')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.title(f'Computation budget vs Accuracy')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "def record_tokens_accuracy(model_name, dataset_list, hard_level, method_list):\n",
    "    tokens_dict = {}\n",
    "    accuracy_dict = {}\n",
    "    for method in method_list:\n",
    "        total_tokens = 0\n",
    "        total_problems = 0\n",
    "        total_accuracy = 0\n",
    "        for dataset in dataset_list: \n",
    "            tokens = 0\n",
    "            if 'gpt' in model_name:\n",
    "                # data_path = f'results/gpt/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "                data_path = f'results/gpt/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "            else:\n",
    "                # data_path = f'results/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "                # data_path = f'results/{model_name}_{dataset}_{hard_level}_{method}_new_eval.jsonl'\n",
    "                data_path = f'results/{model_name}_{dataset}_{hard_level}_{method}_nshots_3_train_eval.jsonl'\n",
    "            data = read_jsonl(data_path)\n",
    "            \n",
    "            problems = len(data)\n",
    "            # correct_numbs = 0\n",
    "            accuracy_numbs = 0\n",
    "            error_numbs = 0\n",
    "\n",
    "            for row in data:\n",
    "                # correct = row['correct']\n",
    "                accuracy = row['accuracy']\n",
    "                accuracy_numbs += accuracy\n",
    "                # if accuracy:\n",
    "                #     accuracy_numbs += 1\n",
    "                # print(accuracy)\n",
    "                try:\n",
    "                    # if method in ['cot', 'pal', 'metamath']:\n",
    "                        # print(row['reasoning_path'])\n",
    "                    for rp in row['reasoning_paths']:\n",
    "                        answer_tokens = count_tokens(rp)\n",
    "                        tokens += answer_tokens\n",
    "                        # print(answer_tokens)\n",
    "                    # elif method in ['nlcode', 'codenl']:\n",
    "                    #     answer_tokens = count_tokens(row['reasoning_path_1']) + count_tokens(row['reasoning_path_2'])\n",
    "                    # tokens += answer_tokens\n",
    "                except Exception as e:\n",
    "                    print(e)\n",
    "                    error_numbs += 1\n",
    "                    print(f\"Error in model {model_name} on dataset {dataset} with method {method}\")\n",
    "            # print(f\"Error numbs for model {model_name} on dataset {dataset} is {error_numbs}\")\n",
    "            problems -= error_numbs # remove the error problems\n",
    "            # print(f\"Average tokens for model {model_name} on dataset {dataset} is {average_tokens}\")\n",
    "            total_tokens += tokens\n",
    "            total_problems += problems\n",
    "            total_accuracy += accuracy_numbs\n",
    "        \n",
    "\n",
    "        total_average_tokens = total_tokens / total_problems / 3\n",
    "        tokens_dict[method] = total_average_tokens\n",
    "        # accuracy = correct_numbs / total_problems\n",
    "        accuracy = total_accuracy / total_problems\n",
    "        accuracy_dict[method] = accuracy\n",
    "        print(f\"Total average tokens for method {method} is {total_average_tokens}\")\n",
    "    return tokens_dict, accuracy_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total average tokens for method cot is 922.80710206995\n",
      "Total average tokens for method pal is 255.46448965024982\n",
      "Total average tokens for method codenl_single is 929.2064596716631\n",
      "Total average tokens for method nlcode_single is 864.8834760885082\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 1.0, 'Computation budget vs Accuracy')"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure()\n",
    "color_palette = ['blue', 'green', 'red', 'purple', 'orange']  # Define a palette of colors\n",
    "\n",
    "dataset_list = ['counting & probability', 'geometry', 'number theory', 'intermediate algebra','precalculus', 'prealgebra']\n",
    "hard_level = \"Level 5\"\n",
    "method_list = ['cot', 'pal', 'codenl_single', 'nlcode_single',]\n",
    "# for model in model_name_list:\n",
    "# for i, model in enumerate(model_name_list):\n",
    "#     # plot_token_accuracy(model, dataset_list, hard_level, method_list)\n",
    "#     plot_token_accuracy(model, dataset_list, hard_level, method_list, color_palette[i])\n",
    "plot_token_accuracy('meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo', dataset_list, hard_level, method_list, color_palette[0])\n",
    "plt.legend()\n",
    "plt.xlabel('Average Tokens')\n",
    "plt.ylabel('Accuracy')\n",
    "plt.title(f'Computation budget vs Accuracy')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "## record the accuracy of PAL and COT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method cot done\n",
      "Method pal done\n",
      "Method codenl done\n",
      "Method nlcode done\n",
      "dict_keys(['cot', 'pal', 'codenl', 'nlcode'])\n"
     ]
    }
   ],
   "source": [
    "method_1 = 'cot' # 'pal'\n",
    "method_2 = 'pal' # 'cot'\n",
    "model = 'meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo'\n",
    "from  reasoner import retrieve_answer_math\n",
    "\n",
    "answer_dict = retrieve_answer_math(model, hard_levels=['Level 5'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Oracle accuracy for cot is 0.2854984894259819\n"
     ]
    }
   ],
   "source": [
    "cot_answer = answer_dict['cot']\n",
    "pal_answer = answer_dict['pal']\n",
    "\n",
    "#\n",
    "answer_cot_list = [] \n",
    "answer_pal_list = []\n",
    "correct_cot_list = []\n",
    "correct_pal_list = []\n",
    "\n",
    "for dataset in cot_answer:\n",
    "    for idx, row in cot_answer[dataset].items():\n",
    "        answer_cot = cot_answer[dataset][idx]\n",
    "        answer_pal = pal_answer[dataset][idx]\n",
    "        correct_cot = answer_cot['correct']\n",
    "        correct_pal = answer_pal['correct']\n",
    "        answer_cot_list.append(answer_cot)\n",
    "        answer_pal_list.append(answer_pal)\n",
    "        correct_cot_list.append(correct_cot)\n",
    "        correct_pal_list.append(correct_pal)\n",
    "\n",
    "# compute the oracle accuracy for cot and pal\n",
    "oracle_correct_cot = 0\n",
    "\n",
    "for i in range(len(correct_cot_list)):\n",
    "    if correct_cot_list[i] or correct_pal_list[i]:\n",
    "        oracle_correct_cot += 1\n",
    "oracle_accuracy_cot = oracle_correct_cot / len(correct_cot_list)\n",
    "print(f\"Oracle accuracy for cot is {oracle_accuracy_cot}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1324 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  2%|▏         | 25/1324 [00:21<18:36,  1.16it/s]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001B[1;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[1;31mKeyboardInterrupt\u001B[0m                         Traceback (most recent call last)",
      "Cell \u001B[1;32mIn[11], line 11\u001B[0m\n\u001B[0;32m      9\u001B[0m     correct_overlap \u001B[38;5;241m+\u001B[39m\u001B[38;5;241m=\u001B[39m \u001B[38;5;241m1\u001B[39m\n\u001B[0;32m     10\u001B[0m \u001B[38;5;28;01mtry\u001B[39;00m:\n\u001B[1;32m---> 11\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m \u001B[43mmath_equal\u001B[49m\u001B[43m(\u001B[49m\u001B[43manswer_cot_list\u001B[49m\u001B[43m[\u001B[49m\u001B[43mi\u001B[49m\u001B[43m]\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43manswer_pal_list\u001B[49m\u001B[43m[\u001B[49m\u001B[43mi\u001B[49m\u001B[43m]\u001B[49m\u001B[43m)\u001B[49m:\n\u001B[0;32m     12\u001B[0m         total_overlap \u001B[38;5;241m+\u001B[39m\u001B[38;5;241m=\u001B[39m \u001B[38;5;241m1\u001B[39m\n\u001B[0;32m     13\u001B[0m \u001B[38;5;28;01mexcept\u001B[39;00m \u001B[38;5;167;01mException\u001B[39;00m \u001B[38;5;28;01mas\u001B[39;00m e:\n",
      "File \u001B[1;32me:\\RA\\Yale NLP\\INCMath\\utils\\grader.py:86\u001B[0m, in \u001B[0;36mmath_equal\u001B[1;34m(prediction, reference, include_percentage, is_close, timeout)\u001B[0m\n\u001B[0;32m     84\u001B[0m \u001B[38;5;66;03m# symbolic equal with sympy\u001B[39;00m\n\u001B[0;32m     85\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m timeout:\n\u001B[1;32m---> 86\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m \u001B[43mcall_with_timeout\u001B[49m\u001B[43m(\u001B[49m\u001B[43msymbolic_equal_process\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mprediction\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mreference\u001B[49m\u001B[43m)\u001B[49m:\n\u001B[0;32m     87\u001B[0m         \u001B[38;5;28;01mreturn\u001B[39;00m \u001B[38;5;28;01mTrue\u001B[39;00m\n\u001B[0;32m     88\u001B[0m \u001B[38;5;28;01melse\u001B[39;00m:\n",
      "File \u001B[1;32me:\\RA\\Yale NLP\\INCMath\\utils\\grader.py:151\u001B[0m, in \u001B[0;36mcall_with_timeout\u001B[1;34m(func, timeout, *args, **kwargs)\u001B[0m\n\u001B[0;32m    149\u001B[0m process \u001B[38;5;241m=\u001B[39m multiprocessing\u001B[38;5;241m.\u001B[39mProcess(target\u001B[38;5;241m=\u001B[39mfunc, args\u001B[38;5;241m=\u001B[39mprocess_args, kwargs\u001B[38;5;241m=\u001B[39mkwargs)\n\u001B[0;32m    150\u001B[0m process\u001B[38;5;241m.\u001B[39mstart()\n\u001B[1;32m--> 151\u001B[0m \u001B[43mprocess\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mjoin\u001B[49m\u001B[43m(\u001B[49m\u001B[43mtimeout\u001B[49m\u001B[43m)\u001B[49m\n\u001B[0;32m    153\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m process\u001B[38;5;241m.\u001B[39mis_alive():\n\u001B[0;32m    154\u001B[0m     process\u001B[38;5;241m.\u001B[39mterminate()\n",
      "File \u001B[1;32md:\\Anaconda3\\envs\\together\\lib\\multiprocessing\\process.py:149\u001B[0m, in \u001B[0;36mBaseProcess.join\u001B[1;34m(self, timeout)\u001B[0m\n\u001B[0;32m    147\u001B[0m \u001B[38;5;28;01massert\u001B[39;00m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39m_parent_pid \u001B[38;5;241m==\u001B[39m os\u001B[38;5;241m.\u001B[39mgetpid(), \u001B[38;5;124m'\u001B[39m\u001B[38;5;124mcan only join a child process\u001B[39m\u001B[38;5;124m'\u001B[39m\n\u001B[0;32m    148\u001B[0m \u001B[38;5;28;01massert\u001B[39;00m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39m_popen \u001B[38;5;129;01mis\u001B[39;00m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;28;01mNone\u001B[39;00m, \u001B[38;5;124m'\u001B[39m\u001B[38;5;124mcan only join a started process\u001B[39m\u001B[38;5;124m'\u001B[39m\n\u001B[1;32m--> 149\u001B[0m res \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43m_popen\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mwait\u001B[49m\u001B[43m(\u001B[49m\u001B[43mtimeout\u001B[49m\u001B[43m)\u001B[49m\n\u001B[0;32m    150\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m res \u001B[38;5;129;01mis\u001B[39;00m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;28;01mNone\u001B[39;00m:\n\u001B[0;32m    151\u001B[0m     _children\u001B[38;5;241m.\u001B[39mdiscard(\u001B[38;5;28mself\u001B[39m)\n",
      "File \u001B[1;32md:\\Anaconda3\\envs\\together\\lib\\multiprocessing\\popen_spawn_win32.py:108\u001B[0m, in \u001B[0;36mPopen.wait\u001B[1;34m(self, timeout)\u001B[0m\n\u001B[0;32m    105\u001B[0m \u001B[38;5;28;01melse\u001B[39;00m:\n\u001B[0;32m    106\u001B[0m     msecs \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mmax\u001B[39m(\u001B[38;5;241m0\u001B[39m, \u001B[38;5;28mint\u001B[39m(timeout \u001B[38;5;241m*\u001B[39m \u001B[38;5;241m1000\u001B[39m \u001B[38;5;241m+\u001B[39m \u001B[38;5;241m0.5\u001B[39m))\n\u001B[1;32m--> 108\u001B[0m res \u001B[38;5;241m=\u001B[39m \u001B[43m_winapi\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mWaitForSingleObject\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;28;43mint\u001B[39;49m\u001B[43m(\u001B[49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43m_handle\u001B[49m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mmsecs\u001B[49m\u001B[43m)\u001B[49m\n\u001B[0;32m    109\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m res \u001B[38;5;241m==\u001B[39m _winapi\u001B[38;5;241m.\u001B[39mWAIT_OBJECT_0:\n\u001B[0;32m    110\u001B[0m     code \u001B[38;5;241m=\u001B[39m _winapi\u001B[38;5;241m.\u001B[39mGetExitCodeProcess(\u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39m_handle)\n",
      "\u001B[1;31mKeyboardInterrupt\u001B[0m: "
     ]
    }
   ],
   "source": [
    "# compute the overlap answer between cot and pal\n",
    "from utils.grader import math_equal\n",
    "import tqdm\n",
    "total_overlap = 0\n",
    "correct_overlap = 0\n",
    "# for i in range(len(correct_cot_list)):\n",
    "for i in tqdm.tqdm(range(len(correct_cot_list))):\n",
    "    if correct_cot_list[i] and correct_pal_list[i]:\n",
    "        correct_overlap += 1\n",
    "    try:\n",
    "        if math_equal(answer_cot_list[i], answer_pal_list[i]):\n",
    "            total_overlap += 1\n",
    "    except Exception as e:\n",
    "        print(e)\n",
    "        print(f\"Error in index {i}\")\n",
    "\n",
    "overlap_rate = total_overlap / len(correct_cot_list)\n",
    "print(f\"Overlap rate is {overlap_rate}\")\n",
    "overlap_correct = correct_overlap / total_overlap\n",
    "print(f\"Overlap correct rate is {overlap_correct}\")\n",
    "\n",
    "overlap_wrong = (total_overlap - correct_overlap) / total_overlap\n",
    "print(f\"Overlap wrong rate is {overlap_wrong}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "from  reasoner import retrieve_answer_math\n",
    "from utils.grader import math_equal\n",
    "import tqdm\n",
    "\n",
    "def record_overlap(model_name):\n",
    "    answer_dict = retrieve_answer_math(model, hard_levels=['Level 5'])\n",
    "    cot_answer = answer_dict['cot']\n",
    "    pal_answer = answer_dict['pal']\n",
    "\n",
    "    #\n",
    "    answer_cot_list = [] \n",
    "    answer_pal_list = []\n",
    "    correct_cot_list = []\n",
    "    correct_pal_list = []\n",
    "\n",
    "    for dataset in cot_answer:\n",
    "        for idx, row in cot_answer[dataset].items():\n",
    "            answer_cot = cot_answer[dataset][idx]['answer']\n",
    "            answer_pal = pal_answer[dataset][idx]['answer']\n",
    "            correct_cot = cot_answer[dataset][idx]['correct']\n",
    "            correct_pal = pal_answer[dataset][idx]['correct']\n",
    "            answer_cot_list.append(answer_cot)\n",
    "            answer_pal_list.append(answer_pal)\n",
    "            correct_cot_list.append(correct_cot)\n",
    "            correct_pal_list.append(correct_pal)\n",
    "\n",
    "    # compute the oracle accuracy for cot and pal\n",
    "    oracle_correct_cot = 0\n",
    "\n",
    "    for i in range(len(correct_cot_list)):\n",
    "        if correct_cot_list[i] or correct_pal_list[i]:\n",
    "            oracle_correct_cot += 1\n",
    "    oracle_accuracy_cot = oracle_correct_cot / len(correct_cot_list)\n",
    "    cot_accuracy = sum(correct_cot_list) / len(correct_cot_list)\n",
    "    pal_accuracy = sum(correct_pal_list) / len(correct_pal_list)\n",
    "\n",
    "    total_overlap = 0\n",
    "    correct_overlap = 0\n",
    "    # for i in range(len(correct_cot_list)):\n",
    "    for i in tqdm.tqdm(range(len(correct_cot_list))):\n",
    "        if correct_cot_list[i] and correct_pal_list[i]:\n",
    "            correct_overlap += 1\n",
    "        try:\n",
    "            if math_equal(answer_cot_list[i], answer_pal_list[i]):\n",
    "                total_overlap += 1\n",
    "        except Exception as e:\n",
    "            print(e)\n",
    "            print(f\"Error in index {i}\")\n",
    "\n",
    "    overlap_rate = total_overlap / len(correct_cot_list)\n",
    "    print(f\"Overlap rate  of model {model_name} is {overlap_rate}\")\n",
    "    overlap_correct = correct_overlap / total_overlap\n",
    "    print(f\"Overlap correct rate of model {model_name} is {overlap_correct}\")\n",
    "\n",
    "    overlap_wrong = (total_overlap - correct_overlap) / total_overlap\n",
    "    print(f\"Overlap wrong rate of model {model_name} is {overlap_wrong}\")\n",
    "\n",
    "    print(f'COT accuracy of model {model_name} is {cot_accuracy}')\n",
    "    print(f'PAL accuracy of model {model_name} is {pal_accuracy}')\n",
    "    print(f\"Oracle accuracy for COT and PAL of model {model_name} is {oracle_accuracy_cot}\")\n",
    "\n",
    "model_name_list = ['meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo', 'meta-llama/Meta-Llama-3.1-70B-Instruct-Turbo',   'gpt-4o-mini']\n",
    "for model in model_name_list:\n",
    "    record_overlap(model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "together",
   "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.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}