{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method cot done\n",
      "Method pal done\n",
      "Method codenl done\n",
      "Method nlcode done\n"
     ]
    }
   ],
   "source": [
    "from utils.utils import write_jsonl\n",
    "from reasoner import retrieve_answer_math\n",
    "import json\n",
    "model_name = 'gpt-4o-mini'\n",
    "method_list = ['cot', 'pal', 'codenl', 'nlcode']\n",
    "answers = retrieve_answer_math(model_name)\n",
    "# arranged_answers = []\n",
    "# for method_name in method_list:\n",
    "#     for key, method_value in answers[method_name].items():\n",
    "#         for idx, answer in method_value.items():\n",
    "#             print(answer)\n",
    "#             answer['method'] = method_name\n",
    "#             answer['idx'] = idx\n",
    "#             arranged_answers.append(answer)\n",
    "# write json file\n",
    "json.dump(answers, open(f'results/{model_name}_answers_new.json', 'w'))\n",
    "# write_jsonl(f'results/{model_name}_answers.jsonl', arranged_answers)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'level': 'Level 5', 'type': 'Algebra', 'question': 'Let \\\\[f(x) = \\\\left\\\\{\\n\\\\begin{array}{cl} ax+3, &\\\\text{ if }x>2, \\\\\\\\\\nx-5 &\\\\text{ if } -2 \\\\le x \\\\le 2, \\\\\\\\\\n2x-b &\\\\text{ if } x <-2.\\n\\\\end{array}\\n\\\\right.\\\\]Find $a+b$ if the piecewise function is continuous (which means that its graph can be drawn without lifting your pencil from the paper).', 'answer': 'For the piecewise function to be continuous, the cases must \"meet\" at $2$ and $-2$. For example, $ax+3$ and $x-5$ must be equal when $x=2$. This implies $a(2)+3=2-5$, which we solve to get $2a=-6 \\\\Rightarrow a=-3$. Similarly, $x-5$ and $2x-b$ must be equal when $x=-2$. Substituting, we get $-2-5=2(-2)-b$, which implies $b=3$. So $a+b=-3+3=\\\\boxed{0}$.', 'idx': 0, 'ground_truth': '0', 'reasoning_path': 'To find the value of $a+b$, we need to ensure that the function is continuous at the points $x=2$ and $x=-2$.\\n\\nFor $x=2$, we have $f(2) = 2 - 5 = -3$. We also have $f(2) = a(2) + 3 = 2a + 3$. Since the function is continuous, we can equate these two expressions:\\n\\n$-3 = 2a + 3$\\n\\nSubtracting 3 from both sides gives:\\n\\n$-6 = 2a$\\n\\nDividing both sides by 2 gives:\\n\\n$a = -3$\\n\\nFor $x=-2$, we have $f(-2) = -2 - 5 = -7$. We also have $f(-2) = 2(-2) - b = -4 - b$. Since the function is continuous, we can equate these two expressions:\\n\\n$-7 = -4 - b$\\n\\nSubtracting -4 from both sides gives:\\n\\n$-3 = -b$\\n\\nMultiplying both sides by -1 gives:\\n\\n$b = 3$\\n\\nNow that we have found the values of $a$ and $b$, we can find their sum:\\n\\n$a + b = -3 + 3 = \\\\boxed{0}$', 'pred_answer': '0'}\n",
      "./new_results/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo_algebra_Level 5_cot_greedy_train.jsonl\n"
     ]
    }
   ],
   "source": [
    "file_name = './new_results/meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo_algebra_Level 5_cot_greedy_train.jsonl'\n",
    "from utils.utils import read_jsonl, write_jsonl\n",
    "data = read_jsonl(file_name)\n",
    "\n",
    "\n",
    "for d in data:\n",
    "    pred_answer = d['pred_answers'][0]\n",
    "    reasoning_paths = d['reasoning_paths'][0]\n",
    "    d['reasoning_path'] = reasoning_paths\n",
    "    d['pred_answer'] = pred_answer\n",
    "\n",
    "    del d['pred_answers']\n",
    "    del d['reasoning_paths']\n",
    "print(data[0])\n",
    "print(file_name)\n",
    "write_jsonl(data, file_name)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "textgen",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
