{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\n",
      "    \"original_question\": \"In 1992, a scoop of gelato could be purchased in Italy for 1200 lire. The same gelato would have cost $\\\\$1.50$ in the U.S. At the equivalent exchange rate between the lire and the dollar, how many dollars would be equivalent to 1,000,000 lire?\",\n",
      "    \"modified_question\": \"In 1992, a scoop of gelato could be purchased in Italy for 1200 lire. The same gelato would have cost $\\\\$1.50$ in the U.S. At the equivalent exchange rate between the lire and the dollar, how many dollars would be equivalent to 1,000,000 lire?\",\n",
      "    \"original_process\": [\n",
      "        \"Let's call the number of dollars x. So, the problem is asking us to solve the equation x=1000000*$\\\\frac{1.50}{1200}$.\",\n",
      "        \"There are two ways to solve this equation. We could either divide 1000000 by 1200 and then multiply the result by 1.50 or we could divide 1.50 by 1200 and then multiply the result by 1000000.\",\n",
      "        \"I think the second way will be easier. $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"That's true. Now we just have to solve the equation x=1000000*0.00125.\",\n",
      "        \"So x=$1250$.\",\n",
      "        \"That's the final answer.\",\n",
      "        \"Right. So 1,000,000 lire is equivalent to $\\\\$1250$.\"\n",
      "    ],\n",
      "    \"modified_process\": [\n",
      "        \"Let's call the number of dollars x. So, the problem is asking us to solve the equation x=1000000*$\\\\frac{1.50}{1200}$.\",\n",
      "        \"There are two ways to solve this equation. We could either divide 1000000 by 1200 and then multiply the result by 1.50 or we could divide 1.50 by 1200 and then multiply the result by 1000000.\",\n",
      "        \"I think the second way will be easier. $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"That's true. But let's confirm the computation again: $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"Now we just have to solve the equation x=1000000*0.00125.\",\n",
      "        \"So x=$1250$.\",\n",
      "        \"Let's double-check by performing the multiplication again: 1000000*0.00125=$1250$.\",\n",
      "        \"That's the final answer.\",\n",
      "        \"Right. So 1,000,000 lire is equivalent to $\\\\$1250$.\"\n",
      "    ],\n",
      "    \"modified_steps\": [4, 7, 8],\n",
      "    \"error_steps\": [4, 7, 8],\n",
      "    \"reason\": \"Step 4 unnecessarily repeats the computation of $\\\\frac{1.50}{1200}$, which was already completed in Step 7 redundantly re-checks the multiplication, adding no new information. These redundant steps make the reasoning process less concise without affecting correctness.\"\n",
      "}\n"
     ]
    }
   ],
   "source": [
    "import os,sys,json\n",
    "import importlib\n",
    "prompt_dir=\"/mnt/petrelfs/songmingyang/code/reasoning/MR_Hallucination/mr_annotate/build_data/prompts/classifications\"\n",
    "sys.path.append(prompt_dir)\n",
    "classifications = os.listdir(prompt_dir)\n",
    "classifications = [c[:-3] for c in classifications if not c.startswith(\"__\")]\n",
    "classifications\n",
    "modules = {classification: importlib.import_module(classification) for classification in classifications}\n",
    "answers = {classification:[] for classification in classifications}\n",
    "for classification in classifications:\n",
    "    answers[classification].append(getattr(modules[classification], f\"{classification}_fewshot_a1\"))\n",
    "    answers[classification].append(getattr(modules[classification], f\"{classification}_fewshot_a2\"))\n",
    "    \n",
    "from copy import deepcopy\n",
    "import re\n",
    "def clean_str(input_str):\n",
    "    res_str = deepcopy(input_str)\n",
    "    res_str = re.sub(r'\\\\+([^\\\\\\s])', r'\\\\\\\\\\1', res_str)\n",
    "    res_str = re.sub(r'\\\\+([\\s])', r'\\\\\\\\\\\\\\\\\\1', res_str)\n",
    "    return res_str\n",
    "print(clean_str(answers[\"redundency\"][1].strip()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_case_from_prompt(prompt):\n",
    "    initial = f\"\\section*{{1. Original Process}}\\n\\n\"\n",
    "    if isinstance(prompt, str):\n",
    "        prompt_dict = json.loads(prompt)\n",
    "    else:\n",
    "        prompt_dict = prompt\n",
    "    original_question = prompt_dict[\"original_question\"]\n",
    "    original_process = prompt_dict[\"original_process\"]\n",
    "    modified_question = prompt_dict[\"modified_question\"]\n",
    "    modified_process = prompt_dict[\"modified_process\"]\n",
    "    reason = prompt_dict[\"reason\"]\n",
    "    res = \"\"\n",
    "\n",
    "    res += initial\n",
    "    res += f\"\\\\textbf{{Question}}: {original_question}\\n\\n\"\n",
    "    \n",
    "    for i, p in enumerate(original_process):\n",
    "        res += f\"\\\\textbf{{Step {i+1}}}: {p}\\n\\n\"\n",
    "    \n",
    "    res += f\"\\section*{{2. Modified Process}}\\n\\n\"\n",
    "    res += f\"\\\\textbf{{Question}}: {modified_question}\\n\\n\"\n",
    "        \n",
    "    for i, p in enumerate(modified_process):\n",
    "        res += f\"\\\\textbf{{Step {i+1}}}: {p}\\n\\n\"\n",
    "        \n",
    "    res += f\"\\section*{{3. Reason}}\\n\\n\"\n",
    "    res += f\"{reason}\\n\\n\"\n",
    "    \n",
    "    return res\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['missing_condition', 'step_contradiction', 'confidence', 'circular', 'counterfactual', 'redundency', 'deception', 'domain_inconsistency'])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "answers.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\section*{1. Original Process}\n",
      "\n",
      "\\textbf{Question}: Given that $\\mathbf{F}(r) = \\left( f(r), g(r), h(r) \\right)$ is a three-dimensional vector, prove that: $\\forall r_1, r_2, \\exists r_1 < r^* < r_2 \\text{ such that } \\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*)$.\n",
      "\n",
      "\\textbf{Step 1}: Understanding the Given Information and Problem\\nWe have a vector function $\\mathbf{F}(r) = \\left( f(r), g(r), h(r) \\right)$, where $f$, $g$, and $h$ are real-valued functions of the real variable $r$. We need to prove that for any $r_1$, $r_2$, there exists an $r^*$ such that $r_1 < r^* < r_2$ and $$\\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*),$$ where $\\nabla \\mathbf{F}(r^*)$ denotes the gradient of $\\mathbf{F}$ at $r^*$ (i.e., a vector composed of the derivatives of each component with respect to $r$).\n",
      "\n",
      "\\textbf{Step 2}: Breaking Down the Problem into Components\\nExpress the vector equation in terms of its components: $$\\left( f(r_1) - f(r_2),\\\\ g(r_1) - g(r_2),\\\\ h(r_1) - h(r_2) \\right) = (r_1 - r_2) \\left( f{\\prime}(r^*),\\\\ g{\\prime}(r^*),\\\\ h{\\prime}(r^*) \\right).$$ Thus, we need to find an $r^* \\in (r_1, r_2)$ such that for each component: $$\\frac{f(r_1) - f(r_2)}{r_1 - r_2} = f{\\prime}(r^*), \\quad \\frac{g(r_1) - g(r_2)}{r_1 - r_2} = g{\\prime}(r^*), \\quad \\frac{h(r_1) - h(r_2)}{r_1 - r_2} = h{\\prime}(r^*).$$\n",
      "\n",
      "\\textbf{Step 3}: Considering the Application of the One-Dimensional Mean Value Theorem\\nIn one dimension, the Mean Value Theorem (MVT) states that for a function $f$ continuous on $[a, b]$ and differentiable on $(a, b)$, there exists $c \\in (a, b)$ such that: $$f(b) - f(a) = f{\\prime}(c)(b - a).$$ Applying the MVT to each component function $f$, $g$, and $h$, we obtain corresponding points $c_f$, $c_g$, and $c_h$. However, these points generally differ ($c_f \\neq c_g \\neq c_h$), so we cannot guarantee the existence of a common $r^*$ where all component equations hold simultaneously.\n",
      "\n",
      "\\textbf{Step 4}: Considering a Counterexample\\nSince we cannot guarantee a common $r^*$ satisfying all components, let’s attempt to find a specific counterexample to demonstrate that the original proposition may not hold.\n",
      "\n",
      "\\textbf{Step 5}: Trying the Function $\\mathbf{F}(r) = (\\sin r,\\\\ \\cos r,\\\\ r)$\\nLet $\\mathbf{F}(r) = (\\sin r,\\\\ \\cos r,\\\\ r)$. Choose two distinct real numbers, for example, $r_1 = 0$ and $r_2 = \\pi$.\n",
      "\n",
      "\\textbf{Step 6}: Compute $\\mathbf{F}(r_1) - \\mathbf{F}(r_2)$:\\n$$\\mathbf{F}(0) - \\mathbf{F}(\\pi) = (\\sin 0 - \\sin \\pi,\\\\ \\cos 0 - \\cos \\pi,\\\\ 0 - \\pi) = (0 - 0,\\\\ 1 - (-1),\\\\ -\\pi) = (0,\\\\ 2,\\\\ -\\pi).$$\n",
      "\n",
      "\\textbf{Step 7}: Compute $(r_1 - r_2) \\nabla \\mathbf{F}(r^*)$:\\n$$(r_1 - r_2) \\left( \\cos r^*,\\\\ -\\sin r^*,\\\\ 1 \\right) = (0 - \\pi) \\left( \\cos r^*,\\\\ -\\sin r^*,\\\\ 1 \\right) = (-\\pi) \\left( \\cos r^*,\\\\ -\\sin r^*,\\\\ 1 \\right).$$\n",
      "\n",
      "\\textbf{Step 8}: We need to find $r^* \\in (0, \\pi)$ such that:\\n$$(0,\\\\ 2,\\\\ -\\pi) = (-\\pi \\cos r^*,\\\\ \\pi \\sin r^*,\\\\ -\\pi).$$\n",
      "\n",
      "\\textbf{Step 9}: This leads to the equations:\\n$$-\\pi \\cos r^* = 0, \\quad \\pi \\sin r^* = 2, \\quad -\\pi = -\\pi.$$\n",
      "\n",
      "\\textbf{Step 10}: The third equation is always true. Simplifying the first two equations:\\nFrom $-\\pi \\cos r^* = 0$: $\\cos r^* = 0.$\n",
      "\n",
      "\\textbf{Step 11}: From $\\pi \\sin r^* = 2$:\\n$$\\sin r^* = \\frac{2}{\\pi}.$$\n",
      "\n",
      "\\textbf{Step 12}: However, $\\cos r^* = 0$ implies $r^* = \\frac{\\pi}{2}$. Substituting $r^* = \\frac{\\pi}{2}$ into the second equation:\\n$$\\sin \\left( \\frac{\\pi}{2} \\right) = 1 \\neq \\frac{2}{\\pi}.$$\n",
      "\n",
      "\\textbf{Step 13}: Since $\\frac{2}{\\pi} \\approx 0.6366$, the equality does not hold. Therefore, there is no $r^*$ in $(0, \\pi)$ that satisfies both equations simultaneously.\n",
      "\n",
      "\\textbf{Step 14}: The above calculations show that for the function $\\mathbf{F}(r) = (\\sin r,\\\\ \\cos r,\\\\ r)$, there does not exist an $r^* \\in (r_1, r_2)$ such that:\\n$$\\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*).$$\n",
      "\n",
      "\\section*{2. Modified Process}\n",
      "\n",
      "\\textbf{Question}: Given that $\\mathbf{F}(r) = \\left( f(r), g(r), h(r) \\right)$ is a three-dimensional vector, prove that: $\\forall r_1, r_2, \\exists r_1 < r^* < r_2 \\text{ such that } \\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*)$.\n",
      "\n",
      "\\textbf{Step 1}: Understanding the Given Information and Problem\\nWe have a vector function $\\mathbf{F}(r) = \\left( f(r),\\\\ g(r),\\\\ h(r) \\right)$, where $f$, $g$, and $h$ are real-valued functions of the real variable $r$. We need to prove that for any $r_1$, $r_2$, there exists an $r^*$ such that $r_1 < r^* < r_2$ and $$\\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*),$$ where $\\nabla \\mathbf{F}(r^*)$ denotes the gradient of $\\mathbf{F}$ at $r^*$ (i.e., a vector composed of the derivatives of each component with respect to $r$).\n",
      "\n",
      "\\textbf{Step 2}: Breaking Down the Problem into Components\\nExpress the vector equation in terms of its components: $$\\left( f(r_1) - f(r_2),\\\\ g(r_1) - g(r_2),\\\\ h(r_1) - h(r_2) \\right) = (r_1 - r_2) \\left( f{\\prime}(r^*),\\\\ g{\\prime}(r^*),\\\\ h{\\prime}(r^*) \\right).$$ Thus, we need to find an $r^* \\in (r_1, r_2)$ such that for each component: $$\\frac{f(r_1) - f(r_2)}{r_1 - r_2} = f{\\prime}(r^*), \\quad \\frac{g(r_1) - g(r_2)}{r_1 - r_2} = g{\\prime}(r^*), \\quad \\frac{h(r_1) - h(r_2)}{r_1 - r_2} = h{\\prime}(r^*).$$\n",
      "\n",
      "\\textbf{Step 3}: Applying the Mean Value Theorem for Vector-Valued Functions\\nThe Mean Value Theorem (MVT) can be extended to vector-valued functions. Specifically, if $\\mathbf{F}(r)$ is continuous on $[r_1, r_2]$ and differentiable on $(r_1, r_2)$, then there exists some $r^* \\in (r_1, r_2)$ such that: $$\\mathbf{F}(r_2) - \\mathbf{F}(r_1) = \\mathbf{F}'(r^*)(r_2 - r_1).$$\n",
      "\n",
      "\\textbf{Step 4}: Expressing the Derivative and Rearranging the Equation\\nRecall that the derivative $\\mathbf{F}'(r)$ is given by: $$\\mathbf{F}'(r) = \\left( f'(r),\\\\ g'(r),\\\\ h'(r) \\right) = \\nabla \\mathbf{F}(r).$$ Rewriting the equation from Step 3: $$\\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\mathbf{F}'(r^*).$$\n",
      "\n",
      "\\textbf{Step 5}: Confirming the Equality Holds Component-Wise\\nThis equation holds for each component: $$\\begin{aligned} f(r_1) - f(r_2) &= (r_1 - r_2) f'(r^*), \\\\ g(r_1) - g(r_2) &= (r_1 - r_2) g'(r^*), \\\\ h(r_1) - h(r_2) &= (r_1 - r_2) h'(r^*). \\end{aligned}$$\n",
      "\n",
      "\\textbf{Step 6}: Concluding the Proof\\nSince all components satisfy the Mean Value Theorem at the same point $r^*$, we have: $$\\mathbf{F}(r_1) - \\mathbf{F}(r_2) = (r_1 - r_2) \\nabla \\mathbf{F}(r^*),$$ where $r^* \\in (r_1, r_2)$.\n",
      "\n",
      "\\textbf{Step 7}: Final Statement\\nTherefore, for any $r_1$ and $r_2$, there exists an $r^*$ between them such that the original equation holds, which completes the proof.\n",
      "\n",
      "\\section*{3. Reason}\n",
      "\n",
      "MVT cannot be used in 3D space, which is a deception or trap, and the counterexample is a good way to show that the proposition may not hold. But we changed it to a correct proof by extending MVT to vector-valued functions and ignoring the restrictions of MVT\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\n",
    "latex_str = get_case_from_prompt(clean_str(answers[\"deception\"][1].strip()))\n",
    "print(latex_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\section*{1. Original Process}\n",
      "\n",
      "\\textbf{Question}: Three pencils and a jumbo eraser cost $\\$1.24$. Five pencils and a jumbo eraser cost $\\$1.82$. No prices include tax. In cents, what is the cost of a pencil?\n",
      "\n",
      "\\textbf{Step 1}: Let's call the price of a pencil p and the price of a jumbo eraser e. Then we can write two equations.\n",
      "\n",
      "\\textbf{Step 2}: We have $3p+e=1.24$ and $5p+e=1.82$.\n",
      "\n",
      "\\textbf{Step 3}: To solve this system, let's subtract the first equation from the second equation. This will eliminate e.\n",
      "\n",
      "\\textbf{Step 4}: $5p+e-3p-e=1.82-1.24$.\n",
      "\n",
      "\\textbf{Step 5}: This simplifies to $2p=0.58$. So $p=0.29$.\n",
      "\n",
      "\\textbf{Step 6}: That means a pencil costs 29 cents.\n",
      "\n",
      "# Answer\n",
      "\n",
      "29\n",
      "\n",
      "\\section*{2. Modified Process}\n",
      "\n",
      "\\textbf{Question}: Three pencils and a jumbo eraser cost $\\$1.24$. Five pencils and a jumbo eraser cost $\\$1.82$. No prices include tax. In cents, what is the cost of a pencil?\n",
      "\n",
      "\\textbf{Step 1}: Step 1. I need to solve this problem to find the cost of a pencil in cents. The problem gives me two scenarios involving pencils and jumbo erasers, along with their total costs. Let's first understand what's being asked.\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 2}: Step 2. The problem states:\n",
      "\n",
      "        - Three pencils and one jumbo eraser cost $1.24.\n",
      "\n",
      "        - Five pencils and one jumbo eraser cost $1.82.\n",
      "\n",
      "        And it asks for the cost of a pencil in cents.\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 3}: Step 3. Since the prices are given in dollars, I should convert them to cents to make calculations easier because the answer is required in cents.\n",
      "\n",
      "        - $1.24 is equal to 124 cents.\n",
      "\n",
      "        - $1.82 is equal to 182 cents.\n",
      "\n",
      "        So, I can rephrase the problem as:\n",
      "\n",
      "        - 3 pencils + 1 jumbo eraser = 124 cents\n",
      "\n",
      "        - 5 pencils + 1 jumbo eraser = 182 cents\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 4}: Step 4. Now, I need to find the cost of one pencil. Let's denote:\n",
      "\n",
      "        - Let p be the cost of one pencil in cents.\n",
      "\n",
      "        - Let e be the cost of one jumbo eraser in cents.\n",
      "\n",
      "        So, I can write the equations based on the given information:\n",
      "\n",
      "        Equation 1: 3p + e = 124\n",
      "\n",
      "        Equation 2: 5p + e = 182\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 5}: Step 5. I have a system of two equations with two variables (p and e). To find the value of p, I can use the method of elimination or substitution. I think elimination might be straightforward here.\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 6}: Step 6. If I subtract Equation 1 from Equation 2, the e (eraser cost) will cancel out, and I can solve for p.\n",
      "\n",
      "        So, Equation 2 - Equation 1:\n",
      "\n",
      "        (5p + e) - (3p + e) = 182 - 124\n",
      "\n",
      "        Simplifying:\n",
      "\n",
      "        5p + e - 3p - e = 58\n",
      "\n",
      "        Which reduces to:\n",
      "\n",
      "        2p = 58\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 7}: Step 7. Now, solving for p:\n",
      "\n",
      "        p = 58 / 2\n",
      "\n",
      "        p = 29 cents\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 8}: Step 8. So, the cost of one pencil is 29 cents. But to make sure, I should check if this makes sense with both original equations.\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 9}: Step 9. Plugging p = 29 into Equation 1:\n",
      "\n",
      "        3(29) + e = 124\n",
      "\n",
      "        87 + e = 124\n",
      "\n",
      "        e = 124 - 87\n",
      "\n",
      "        e = 37 cents\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 10}: Step 10. Now, plugging p = 29 and e = 37 into Equation 2 to verify:\n",
      "\n",
      "        5(29) + 37 = 145 + 37 = 182 cents, which matches the second equation.\n",
      "\n",
      "        \n",
      "\n",
      "\\textbf{Step 11}: Step 11. Everything checks out, so the cost of a pencil is indeed 29 cents.\n",
      "\n",
      "        # Final Answer\n",
      "\n",
      "        \\[\\boxed{29}\\]\n",
      "\n",
      "\\section*{3. Reason}\n",
      "\n",
      "\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "from mr_eval.utils.utils import process_jsonl\n",
    "\n",
    "ms_instances = process_jsonl(\"/mnt/petrelfs/songmingyang/code/reasoning/MR_Hallucination/mr_annotate/build_data/selection_of_data/new_8_classes/one_question_multi_answer/prm_test_p12_multi_solutions.jsonl\")\n",
    "ms_instance = ms_instances[0]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{\n",
      "    \"original_question\": \"In 1992, a scoop of gelato could be purchased in Italy for 1200 lire. The same gelato would have cost $\\\\$1.50$ in the U.S. At the equivalent exchange rate between the lire and the dollar, how many dollars would be equivalent to 1,000,000 lire?\",\n",
      "    \"modified_question\": \"In 1992, a scoop of gelato could be purchased in Italy for 1200 lire. The same gelato would have cost $\\\\$1.50$ in the U.S. At the equivalent exchange rate between the lire and the dollar, how many dollars would be equivalent to 1,000,000 lire?\",\n",
      "    \"original_process\": [\n",
      "        \"Let's call the number of dollars x. So, the problem is asking us to solve the equation x=1000000*$\\\\frac{1.50}{1200}$.\",\n",
      "        \"There are two ways to solve this equation. We could either divide 1000000 by 1200 and then multiply the result by 1.50 or we could divide 1.50 by 1200 and then multiply the result by 1000000.\",\n",
      "        \"I think the second way will be easier. $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"That's true. Now we just have to solve the equation x=1000000*0.00125.\",\n",
      "        \"So x=$1250$.\",\n",
      "        \"That's the final answer.\",\n",
      "        \"Right. So 1,000,000 lire is equivalent to $\\\\$1250$.\"\n",
      "    ],\n",
      "    \"modified_process\": [\n",
      "        \"Let's call the number of dollars x. So, the problem is asking us to solve the equation x=1000000*$\\\\frac{1.50}{1200}$.\",\n",
      "        \"There are two ways to solve this equation. We could either divide 1000000 by 1200 and then multiply the result by 1.50 or we could divide 1.50 by 1200 and then multiply the result by 1000000.\",\n",
      "        \"I think the second way will be easier. $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"That's true. But let's confirm the computation again: $\\\\frac{1.50}{1200}=0.00125$.\",\n",
      "        \"Now we just have to solve the equation x=1000000*0.00125.\",\n",
      "        \"So x=$1250$.\",\n",
      "        \"Let's double-check by performing the multiplication again: 1000000*0.00125=$1250$.\",\n",
      "        \"That's the final answer.\",\n",
      "        \"Right. So 1,000,000 lire is equivalent to $\\\\$1250$.\"\n",
      "    ],\n",
      "    \"modified_steps\": [4, 7, 8],\n",
      "    \"error_steps\": [4, 7, 8],\n",
      "    \"reason\": \"Step 4 unnecessarily repeats the computation of $\\\\frac{1.50}{1200}$, which was already completed in Step 7 redundantly re-checks the multiplication, adding no new information. These redundant steps make the reasoning process less concise without affecting correctness.\"\n",
      "}\n"
     ]
    }
   ],
   "source": [
    "latex_str = get_case_from_prompt(ms_instance)\n",
    "print(latex_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "smoe",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
