{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import re\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_json_data(file_path):\n",
    "    \"\"\"Loads data from a JSON file.\"\"\"\n",
    "    with open(file_path, 'r') as file:\n",
    "        return json.load(file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_final_answer(response_text):\n",
    "    \"\"\"\n",
    "    Extracts the numerical part or special keywords of the final answer from the response text.\n",
    "    \"\"\"\n",
    "    if response_text is None:\n",
    "        return 'N/A'\n",
    "    special_keywords = ['Unknown', 'None']\n",
    "    pattern = r\"Final Numerical Answer.*?:.*?([-+]?[0-9]*\\.?[0-9]+(?:[eE][-+]?[0-9]+)?|\\bUnknown\\b|\\bNone\\b)\"\n",
    "    match = re.search(pattern, response_text, re.DOTALL)\n",
    "    if match:\n",
    "        if match.group(1) in special_keywords:\n",
    "            return match.group(1)  # return special keyword\n",
    "        return float(match.group(1))  # convert numeric answers to float\n",
    "    return 'N/A'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_final_answer_from_response(item):\n",
    "    \"\"\"\n",
    "    Converts the final answer to float, if it is a number.\n",
    "    \"\"\"\n",
    "    special_outcomes = ['Unknown', 'None']\n",
    "    final_answer = extract_final_answer(item[\"response\"])\n",
    "    if (final_answer not in special_outcomes) and (final_answer != 'N/A'):\n",
    "        final_answer = round(final_answer, 6)\n",
    "    return final_answer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prep_data_mapping(data):\n",
    "    \"\"\"\n",
    "    Converts data to a dataframe.\n",
    "    \"\"\"\n",
    "    data_list = [\n",
    "        {\n",
    "            \"id\": item[\"id\"],\n",
    "            \"template_id\": item[\"template_id\"],\n",
    "            \"problem\": item[\"problem\"],\n",
    "            \"full_solution\": item[\"full_solution\"],\n",
    "            \"expected\": item[\"answer\"],\n",
    "            \"category\": item[\"category\"],\n",
    "            \"level\": item[\"level\"],\n",
    "            \"source\": item[\"source\"],\n",
    "            \"netlist\": item[\"netlist\"]\n",
    "        }\n",
    "        for item in data\n",
    "    ]\n",
    "\n",
    "    # convert to dataframe\n",
    "    df = pd.DataFrame(data_list)\n",
    "    return df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prep_image_mapping(data):\n",
    "    data_list = [\n",
    "        {\n",
    "            \"id\": item[\"id\"],\n",
    "            \"images\": item[\"images\"]\n",
    "        }\n",
    "        for item in data\n",
    "    ]\n",
    "\n",
    "    # convert to dataframe\n",
    "    df = pd.DataFrame(data_list)\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_image(image_data, PROBLEM_ID):\n",
    "    dp = image_data[image_data[\"id\"] == PROBLEM_ID]\n",
    "    im_dict = dp[\"images\"].to_dict()\n",
    "    first_key = next(iter(im_dict))\n",
    "    nested_dict = im_dict[first_key]\n",
    "    try:\n",
    "        im_value = next(iter(nested_dict.values()))\n",
    "    except:\n",
    "        return None\n",
    "\n",
    "    return im_value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def prep_response_mapping(responses):\n",
    "    \"\"\"\n",
    "    Converts responses to a dataframe.\n",
    "    \"\"\"\n",
    "    response_list = [\n",
    "        {\n",
    "            \"id\": item[\"problem_id\"],\n",
    "            \"response\": item[\"response\"],\n",
    "            \"final_answer\": get_final_answer_from_response(item)\n",
    "        }\n",
    "        for item in responses\n",
    "    ]\n",
    "\n",
    "    # convert to dataframe\n",
    "    df = pd.DataFrame(response_list)\n",
    "    return df\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def merge_dataframes(data, responses):\n",
    "    \"\"\"\n",
    "    Merges data and responses into one dataframe containing their combined information.\n",
    "    \"\"\"\n",
    "    # prepare dataframes\n",
    "    df_data = prep_data_mapping(data)\n",
    "    df_responses = prep_response_mapping(responses)\n",
    "\n",
    "    # merge dataframes on id, keeping all rows from df_responses\n",
    "    merged_df = pd.merge(df_responses, df_data, on=\"id\", how=\"left\")\n",
    "\n",
    "    return merged_df\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "DATA_PATH = \"../data/new/data.json\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = load_json_data(DATA_PATH)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_df = prep_data_mapping(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "image_data = prep_image_mapping(data)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Responses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_responses(EXPERIMENT_NUM, WITH_NETLIST = True):\n",
    "    PATH = f\"../run/outputs/resp-experiment-{EXPERIMENT_NUM}.json\"\n",
    "    r = load_json_data(PATH)\n",
    "    data = load_json_data(DATA_PATH)\n",
    "    resps = merge_dataframes(data, r)\n",
    "\n",
    "    wno = resps[resps['netlist'].notna() & resps['netlist'].ne('')].copy()\n",
    "    nno = resps[resps['netlist'].isna()  | resps['netlist'].eq('')].copy()\n",
    "\n",
    "    if WITH_NETLIST:\n",
    "        return wno\n",
    "    else:\n",
    "        return nno"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Response Display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from IPython.display import display, Latex, Markdown, Image, HTML\n",
    "import base64\n",
    "import io\n",
    "\n",
    "def preprocess_latex(text):\n",
    "    # Replace \\( ... \\) with $ ... $\n",
    "    text = re.sub(r'\\\\\\(', r'$', text)\n",
    "    text = re.sub(r'\\\\\\)', r'$', text)\n",
    "\n",
    "    # Replace \\[ ... \\] with $$ ... $$\n",
    "    text = re.sub(r'\\\\\\[', r'$$', text)\n",
    "    text = re.sub(r'\\\\\\]', r'$$', text)\n",
    "\n",
    "    return text\n",
    "\n",
    "# Function to generate and display the content for a single problem\n",
    "def display_problem(EXPERIMENT_NUM, WITH_NETLIST, problem_id):\n",
    "    # Filter the DataFrame for the specific problem ID\n",
    "    df = load_responses(EXPERIMENT_NUM, WITH_NETLIST)\n",
    "    entry = df[df['id'] == problem_id].iloc[0].to_dict()\n",
    "\n",
    "    im = get_image(image_data, problem_id)\n",
    "    # if im is not None:\n",
    "    #     im = base64.b64decode(im)\n",
    "    #     display(Image(data=im, height=50))\n",
    "    if im is not None:\n",
    "        im = base64.b64decode(im)\n",
    "        image_html = f'<img src=\"data:image/png;base64,{base64.b64encode(im).decode()}\" style=\"height:400px;\">'\n",
    "        display(HTML(image_html))\n",
    "\n",
    "    netlist = entry['netlist']\n",
    "    if netlist is not None:\n",
    "    # Preprocess and display the problem using Latex\n",
    "        display(Markdown(\"**NETLIST:**\"))\n",
    "        display(Latex(netlist))\n",
    "\n",
    "    # Display the ID and Template ID\n",
    "    display(Markdown(f\"**ID:** {entry['id']}\"))\n",
    "    display(Markdown(f\"**TEMPLATE ID:** {entry['template_id']}\"))\n",
    "\n",
    "    # Preprocess and display the problem using Latex\n",
    "    display(Markdown(\"**PROBLEM:**\"))\n",
    "    display(Latex(preprocess_latex(entry[\"problem\"])))\n",
    "\n",
    "    # Preprocess and display the full solution using Latex\n",
    "    display(Markdown(\"**FULL SOLUTION:**\"))\n",
    "    display(Latex(preprocess_latex(entry[\"full_solution\"])))\n",
    "\n",
    "    # Preprocess and display the expected answer\n",
    "    display(Markdown(\"**EXPECTED ANSWER:**\"))\n",
    "    display(Latex(preprocess_latex(entry[\"expected\"])))\n",
    "\n",
    "    # Preprocess and display the response using Latex\n",
    "    display(Markdown(\"**RESPONSE:**\"))\n",
    "    display(Latex(preprocess_latex(entry[\"response\"])))\n",
    "\n",
    "    # PRINT RAW RESPONSE\n",
    "    # print()\n",
    "    # print(entry[\"response\"])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Human Error Analysis"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "`display_response(EXPERIMENT_NUM, WITH_NETLIST, QUESTION_ID)`\n",
    "\n",
    "gpt 4o 1-shot no netlist data with no netlists -- `EXPERIMENT_NUM = 7, WITH_NETLIST = False`\n",
    "\n",
    "gpt 4o 0-shot with netlist data with netlists --  `EXPERIMENT_NUM = 6, WITH_NETLIST = True`\n",
    "\n",
    "gpt 4o 1-shot with netlist data with netlists --  `EXPERIMENT_NUM = 8, WITH_NETLIST = True`"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Modify the `EXPERIMENT_NUM`, `WITH_NETLIST`, and `problem_id` in the cell below to access the desired problem."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,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pQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwB2Qv/u7v2ufAUB9Tz31VPsMliNwB+SZZ55pn232xBNPtM8AoI4LFy60z2A5AreAa6+9tn0GAIDAHZBbbrmlfbbZwYMH22cAUMcrXvGK9hksR+AOyPXXX98+A4D6brzxxvYZLEfgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEAKEXgAgBQisAFAKAUgQsAQCkCFwCAUgQuAAClCFwAAEoRuAAAlCJwAQAoReACAFCKwAUAoBSBCwBAKQIXAIBSBC4AAKUIXAAAShG4AACUInABAChF4AIAUIrABQCgFIELAEApAhcAgFIELgAApQhcAABKEbgAAJQicAEA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\" style=\"height:400px;\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**NETLIST:**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/latex": [
       "```\n",
       "V N1 0 ; -I\n",
       "R N1 0 \n",
       "```"
      ],
      "text/plain": [
       "<IPython.core.display.Latex object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**ID:** 106"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**TEMPLATE ID:** 10000"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**PROBLEM:**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/latex": [
       "Determine the current $I$ in Amperes in the circuit in the figure 10000-01. Assume that $V = 1 V$ and $R = 1 \\Omega$."
      ],
      "text/plain": [
       "<IPython.core.display.Latex object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**FULL SOLUTION:**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/latex": [
       "$I = V/R$"
      ],
      "text/plain": [
       "<IPython.core.display.Latex object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**EXPECTED ANSWER:**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/latex": [
       "1"
      ],
      "text/plain": [
       "<IPython.core.display.Latex object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/markdown": [
       "**RESPONSE:**"
      ],
      "text/plain": [
       "<IPython.core.display.Markdown object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/latex": [
       "To determine the current $I$ in the given circuit, we can use Ohm's Law. According to Ohm's Law:\n",
       "\n",
       "$$ V = IR $$\n",
       "\n",
       "Where:\n",
       "- $ V $ is the voltage across the resistor,\n",
       "- $ I $ is the current through the circuit,\n",
       "- $ R $ is the resistance.\n",
       "\n",
       "Given values:\n",
       "$$ V = 1 \\, V $$\n",
       "$$ R = 1 \\, \\Omega $$\n",
       "\n",
       "We need to solve for $ I $:\n",
       "\n",
       "$$ I = \\frac{V}{R} $$\n",
       "$$ I = \\frac{1 \\, V}{1 \\, \\Omega} $$\n",
       "$$ I = 1 \\, A $$\n",
       "\n",
       "Final Numerical Answer: 1.000000"
      ],
      "text/plain": [
       "<IPython.core.display.Latex object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "display_problem(EXPERIMENT_NUM=6, WITH_NETLIST=True, problem_id=106) # TODO MODIFY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
