{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/cluster/home/kevidu/micromamba/envs/sftcontext/lib/python3.10/site-packages/transformers/utils/hub.py:127: FutureWarning: Using `TRANSFORMERS_CACHE` is deprecated and will be removed in v5 of Transformers. Use `HF_HOME` instead.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "from collections import defaultdict\n",
    "import numpy as np\n",
    "import random\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "import seaborn as sns\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from dataset import load_dataset_from_path\n",
    "from datasets import load_dataset, Dataset\n",
    "from utils import partition_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>query_no_mod</th>\n",
       "      <th>query</th>\n",
       "      <th>prior_answer</th>\n",
       "      <th>context</th>\n",
       "      <th>ctx_answer</th>\n",
       "      <th>query_depth</th>\n",
       "      <th>ctx_depth</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>(2 * 4) - 3</td>\n",
       "      <td>(2 * 4) - 3 =</td>\n",
       "      <td>5</td>\n",
       "      <td>(2 * 4) - 3 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2 + 0</td>\n",
       "      <td>2 + 0 =</td>\n",
       "      <td>2</td>\n",
       "      <td>0 = 4</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1 * 6</td>\n",
       "      <td>1 * 6 =</td>\n",
       "      <td>6</td>\n",
       "      <td>1 * 6 = 4</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>8 - 4</td>\n",
       "      <td>8 - 4 =</td>\n",
       "      <td>4</td>\n",
       "      <td>8 - 4 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>((1 - 4) + 5) + 4</td>\n",
       "      <td>((1 - 4) + 5) + 4 =</td>\n",
       "      <td>6</td>\n",
       "      <td>1 = 0</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4995</th>\n",
       "      <td>((5 + 4) - 0) - 1</td>\n",
       "      <td>((5 + 4) - 0) - 1 =</td>\n",
       "      <td>8</td>\n",
       "      <td>(5 + 4) = 8</td>\n",
       "      <td>7</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4996</th>\n",
       "      <td>((8 - 1) - 3) * 2</td>\n",
       "      <td>((8 - 1) - 3) * 2 =</td>\n",
       "      <td>8</td>\n",
       "      <td>(8 - 1) = 6</td>\n",
       "      <td>6</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4997</th>\n",
       "      <td>((4 * 0) - 0) * 0</td>\n",
       "      <td>((4 * 0) - 0) * 0 =</td>\n",
       "      <td>0</td>\n",
       "      <td>((4 * 0) - 0) * 0 = 3</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4998</th>\n",
       "      <td>((0 - 0) + 7) - 3</td>\n",
       "      <td>((0 - 0) + 7) - 3 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 - 0) + 7) - 3 = 0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4999</th>\n",
       "      <td>((0 * 9) + 4) * 1</td>\n",
       "      <td>((0 * 9) + 4) * 1 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 * 9) + 4) * 1 = 5</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5000 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           query_no_mod                query  prior_answer  \\\n",
       "0           (2 * 4) - 3        (2 * 4) - 3 =             5   \n",
       "1                 2 + 0              2 + 0 =             2   \n",
       "2                 1 * 6              1 * 6 =             6   \n",
       "3                 8 - 4              8 - 4 =             4   \n",
       "4     ((1 - 4) + 5) + 4  ((1 - 4) + 5) + 4 =             6   \n",
       "...                 ...                  ...           ...   \n",
       "4995  ((5 + 4) - 0) - 1  ((5 + 4) - 0) - 1 =             8   \n",
       "4996  ((8 - 1) - 3) * 2  ((8 - 1) - 3) * 2 =             8   \n",
       "4997  ((4 * 0) - 0) * 0  ((4 * 0) - 0) * 0 =             0   \n",
       "4998  ((0 - 0) + 7) - 3  ((0 - 0) + 7) - 3 =             4   \n",
       "4999  ((0 * 9) + 4) * 1  ((0 * 9) + 4) * 1 =             4   \n",
       "\n",
       "                    context  ctx_answer  query_depth  ctx_depth  \n",
       "0           (2 * 4) - 3 = 9           9            2          2  \n",
       "1                     0 = 4           6            1          0  \n",
       "2                 1 * 6 = 4           4            1          1  \n",
       "3                 8 - 4 = 9           9            1          1  \n",
       "4                     1 = 0           5            3          0  \n",
       "...                     ...         ...          ...        ...  \n",
       "4995            (5 + 4) = 8           7            3          1  \n",
       "4996            (8 - 1) = 6           6            3          1  \n",
       "4997  ((4 * 0) - 0) * 0 = 3           3            3          3  \n",
       "4998  ((0 - 0) + 7) - 3 = 0           0            3          3  \n",
       "4999  ((0 * 9) + 4) * 1 = 5           5            3          3  \n",
       "\n",
       "[5000 rows x 7 columns]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ROOT_DATA_DIR = \"../data/Arithmetic/\"\n",
    "RAW_DATA_PATH = os.path.join(ROOT_DATA_DIR, \"arithmetic_dataset.csv\")\n",
    "df = load_dataset_from_path(RAW_DATA_PATH)\n",
    "df = df.drop_duplicates([\"query\"])\n",
    "df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### EDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "query              \n",
       "((0 * 0) * 8) + 4 =    1\n",
       "(0 + 2) * 1 =          1\n",
       "(0 + 3) + 0 =          1\n",
       "(0 + 2) - 1 =          1\n",
       "(0 + 2) - 0 =          1\n",
       "                      ..\n",
       "((4 - 0) - 8) + 8 =    1\n",
       "((4 - 0) - 8) + 7 =    1\n",
       "((4 - 0) - 6) + 8 =    1\n",
       "((4 - 0) - 4) + 9 =    1\n",
       "9 - 8 =                1\n",
       "Name: count, Length: 5000, dtype: int64"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.value_counts([\"query\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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cYdmzpypqKgotWrVStOnT1f79u1L9dOxY0c9//zzl+y7pKREEyZMUMOGDRUSEqLJkyeX+oZswzA0a9YsNW/eXH5+furQoYP++7//21y/Zs0a2Ww2ffHFF+rQoYN8fX3VuXNnff/99+b6Bx98UHl5ebLZbLLZbEpKSjLHnzx5UiNHjlRgYKCaNGmid95555J9AwDqJrcGooULF+qaa65RgwYN1KBBA8XHx+urr74y1xuGoaSkJEVFRcnPz0/du3fXzp07XT6jqKhI48aNU2hoqOrXr6+BAwfq0KFDLjVOp1MJCQmy2+2y2+1KSEjgFsj/9+STT2r16tVavny5VqxYoTVr1igzM7PC40+ePKkePXooICBA69at0/r16xUQEKB+/fqpuLjYrFu1apV2796t9PR0/etf/9LIkSO1a9cubdmyxazZvn27tm3bdsmfBpGk119/Xe+//74WLVqk9evX67ffftPy5ctdav72t78pOTlZCxcu1M6dO/XEE0/o/vvv19q1a0sdg9dee01btmxRWFiYBg4cqDNnzqhr166aO3euGjRoIIfDIYfDoUmTJrn00KlTJ23btk1jx47VX//6V/3www8VPnYAgLrDrYGocePGevnll7V161Zt3bpVt956qwYNGmSGnlmzZmn27NlasGCBtmzZooiICPXu3VsFBQXmZyQmJmr58uVKTU3V+vXrVVhYqAEDBqikpMSsGTZsmLKyspSWlqa0tDRlZWUpISGh1ve3riksLNSiRYv02muvqXfv3mrfvr0WL17scuwuJTU1VfXq1dN7772n9u3bq02bNkpOTtaBAwe0Zs0as65+/fp677331K5dO8XFxalx48bq27evkpOTzZrk5GTdcsstat68+SW3O3fuXE2ZMkV33XWX2rRpo7feekt2u91cf+LECc2ePVvvv/+++vbtq+bNm2vEiBG6//779fbbb7t81tSpU132//Dhw1q+fLm8vb1lt9tls9kUERGhiIgIBQQEmONuu+02jR07Vi1atNBTTz2l0NBQl30GAFw+3PoM0e233+4y/9JLL2nhwoXKyMhQ27ZtNXfuXD377LMaPHiwJGnx4sUKDw/Xhx9+qDFjxigvL0+LFi3SkiVL1KtXL0nS0qVLFR0drZUrV6pv377avXu30tLSlJGRoc6dO0uS3n33XcXHx2vPnj2KjS37+Z6ioiIV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8GCXecMw5HA4tHXrVj333HPV0hgAoHY5HA61bBWrE4UFlRpXPyBQe3/cQyjCZa1Kgchut7vM16tXT7GxsZo+fbr69OlTLY0BAGqX0+nUicICdRv7igIaNa7QmMIjh7T+zafkdDoJRLisVSkQJScnV3cfAIA6IqBRY9mjYtzdBlCr/tQzRJmZmdq9e7dsNpvatm2r6667rrr6AgAAqDVVCkS5ubm65557tGbNGjVs2FCGYSgvL089evRQamqqGjVqVN19AgAA1JgqvXY/btw45efna+fOnfrtt9/kdDq1Y8cO5efna/z48dXdIwAAQI2q0hWitLQ0rVy5Um3atDGXtW3bVm+88QYPVQMAgMtOla4QnTt3Tl5eXqWWe3l56dy5c3+6KQAAgNpUpUB066236vHHH9evv/5qLvvll1/0xBNPqGfPntXWHAAAQG2oUiBasGCBCgoK1KxZM1199dVq0aKFYmJiVFBQoPnz51d3jwAAADWqSs8QRUdH69///rfS09P1ww8/yDAMtW3bVr169aru/gAAAGpcpa4QffPNN2rbtq3y8/MlSb1799a4ceM0fvx43XDDDWrXrp2+/fbbGmkUAACgplQqEM2dO1ejR49WgwYNSq2z2+0aM2aMZs+eXW3NAQAA1IZKBaL//Oc/6tevX7nr+/Tpo8zMzD/dFAAAQG2qVCA6fPhwma/bn+fp6akjR4786aYAAABqU6UC0VVXXaXvv/++3PXbt2+v1K8dr1u3TrfffruioqJks9n02WefuawfMWKEbDaby9SlSxeXmqKiIo0bN06hoaGqX7++Bg4cqEOHDrnUOJ1OJSQkyG63y263KyEhQcePH69wnwAA4MpWqUB022236fnnn9fp06dLrTt16pSmTp2qAQMGVPjzTpw4oQ4dOmjBggXl1vTr108Oh8OcvvzyS5f1iYmJWr58uVJTU7V+/XoVFhZqwIABKikpMWuGDRumrKwspaWlKS0tTVlZWUpISKhwnwAA4MpWqdfu//a3v+nTTz9Vq1at9Nhjjyk2NlY2m027d+/WG2+8oZKSEj377LMV/rz+/furf//+F63x8fFRREREmevy8vK0aNEiLVmyxHzlf+nSpYqOjtbKlSvVt29f7d69W2lpacrIyFDnzp0lSe+++67i4+O1Z88excbGVrhfAABwZapUIAoPD9eGDRv017/+VVOmTJFhGJIkm82mvn376s0331R4eHi1NrhmzRqFhYWpYcOGuuWWW/TSSy8pLCxMkpSZmakzZ864/H5aVFSU4uLitGHDBvXt21cbN26U3W43w5AkdenSRXa7XRs2bCg3EBUVFamoqMicP/9VAwAA4MpT6S9mbNq0qb788ks5nU7t27dPhmGoZcuWCgoKqvbm+vfvr7vvvltNmzZVdna2nnvuOd16663KzMyUj4+PcnJy5O3tXWrb4eHhysnJkSTl5OSYAeqPwsLCzJqyzJw5U9OmTaveHQIAAHVSlb6pWpKCgoJ0ww03VGcvpQwdOtT8Oy4uTp06dVLTpk31xRdfaPDgweWOMwxDNpvNnP/j3+XVXGjKlCmaMGGCOZ+fn6/o6OjK7gIAALgMVOm3zNwlMjJSTZs21d69eyVJERERKi4ultPpdKnLzc01b91FRETo8OHDpT7ryJEjF7295+PjowYNGrhMAADgynRZBaJjx47p4MGD5qv9HTt2lJeXl9LT080ah8OhHTt2qGvXrpKk+Ph45eXlafPmzWbNpk2blJeXZ9YAAABrq/Its+pQWFioffv2mfPZ2dnKyspScHCwgoODlZSUpLvuukuRkZHav3+/nnnmGYWGhurOO++U9PvPhYwaNUoTJ05USEiIgoODNWnSJLVv395866xNmzbq16+fRo8erbfffluS9PDDD2vAgAG8YQYAACS5ORBt3bpVPXr0MOfPP7MzfPhwLVy4UN9//70++OADHT9+XJGRkerRo4c++ugjBQYGmmPmzJkjT09PDRkyRKdOnVLPnj2VkpIiDw8Ps2bZsmUaP368+TbawIEDL/rdRwAAwFrcGoi6d+9uvrpflq+//vqSn+Hr66v58+dr/vz55dYEBwdr6dKlVeoRAABc+S6rZ4gAAABqAoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYHoEIAABYnqe7GwAAAFeeffv2Vao+KChIkZGRNdTNpRGIAABAtTlz5owkadCgQZUa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qTE///yzJGn7wQIVnq7Yl/H9fOTU72O2b1dhYWGFt2Wz2WQYRqX6q8qY2txWXd6n8//bHv9ln84WnazQmPxfsyVJe3JOaPNPFfvJj6qeD9KVd8zr+pja2lZtnXtS3f/nUV3+36k2x9T2P48KCwur/d+z5z/vkvtuWMAvv/xiSDK+++47l+UvvfSS0apVqzLHTJ061ZDExMTExMTEdAVMBw8evGhWsMQVovNsNpvLvGEYpZadN2XKFE2YMMGcP3funH777TeFhISUO6Yq8vPzFR0drYMHD6pBgwbV9rlXIo5V5XC8Ko5jVXEcq4rjWFVcTR4rwzBUUFCgqKioi9ZZIhCFhobKw8NDOTk5Lstzc3MVHh5e5hgfHx/5+Pi4LGvYsGFNtagGDRrwf5gK4lhVDser4jhWFcexqjiOVcXV1LGy2+2XrLHEQ9Xe3t7q2LGj0tPTXZanp6era9eubuoKAADUFZa4QiRJEyZMUEJCgjp16qT4+Hi98847OnDggB555BF3twYAANzMMoFo6NChOnbsmKZPny6Hw6G4uDh9+eWXatq0qVv78vHx0dSpU0vdnkNpHKvK4XhVHMeq4jhWFcexqri6cKxshlGF9woBAACuIJZ4hggAAOBiCEQAAMDyCEQAAMDyCEQAAMDyCES14M0331RMTIx8fX3VsWNHffvttxetX7t2rTp27ChfX181b95cb731Vi116n6VOVZr1qyRzWYrNf3www+12LF7rFu3TrfffruioqJks9n02WefXXKMVc+ryh4rK59XM2fO1A033KDAwECFhYXpjjvu0J49ey45zornVlWOlVXPrYULF+qaa64xv3QxPj5eX3311UXHuOOcIhDVsI8++kiJiYl69tlntW3bNt10003q37+/Dhw4UGZ9dna2brvtNt10003atm2bnnnmGY0fP16ffPJJLXde+yp7rM7bs2ePHA6HObVs2bKWOnafEydOqEOHDlqwYEGF6q18XlX2WJ1nxfNq7dq1evTRR5WRkaH09HSdPXtWffr00YkTJ8odY9VzqyrH6jyrnVuNGzfWyy+/rK1bt2rr1q269dZbNWjQIO3cubPMeredU9Xy66ko14033mg88sgjLstat25tPP3002XWT5482WjdurXLsjFjxhhdunSpsR7risoeq9WrVxuSDKfTWQvd1V2SjOXLl1+0xsrn1R9V5FhxXv2f3NxcQ5Kxdu3acms4t35XkWPFufV/goKCjPfee6/Mde46p7hCVIOKi4uVmZmpPn36uCzv06ePNmzYUOaYjRs3lqrv27evtm7dqjNnztRYr+5WlWN13nXXXafIyEj17NlTq1evrsk2L1tWPa/+DM4rKS8vT5IUHBxcbg3n1u8qcqzOs/K5VVJSotTUVJ04cULx8fFl1rjrnCIQ1aCjR4+qpKSk1A/IhoeHl/qh2fNycnLKrD979qyOHj1aY726W1WOVWRkpN555x198skn+vTTTxUbG6uePXtq3bp1tdHyZcWq51VVcF79zjAMTZgwQd26dVNcXFy5dZxbFT9WVj63vv/+ewUEBMjHx0ePPPKIli9frrZt25ZZ665zyjI/3eFONpvNZd4wjFLLLlVf1vIrUWWOVWxsrGJjY835+Ph4HTx4UK+99ppuvvnmGu3zcmTl86oyOK9+99hjj2n79u1av379JWutfm5V9FhZ+dyKjY1VVlaWjh8/rk8++UTDhw/X2rVryw1F7jinuEJUg0JDQ+Xh4VHqCkdubm6p9HteREREmfWenp4KCQmpsV7drSrHqixdunTR3r17q7u9y55Vz6vqYrXzaty4cfr888+1evVqNW7c+KK1Vj+3KnOsymKVc8vb21stWrRQp06dNHPmTHXo0EHz5s0rs9Zd5xSBqAZ5e3urY8eOSk9Pd1menp6url27ljkmPj6+VP2KFSvUqVMneXl51Viv7laVY1WWbdu2KTIysrrbu+xZ9byqLlY5rwzD0GOPPaZPP/1U33zzjWJiYi45xqrnVlWOVVmscm5dyDAMFRUVlbnObedUjT6yDSM1NdXw8vIyFi1aZOzatctITEw06tevb+zfv98wDMN4+umnjYSEBLP+559/Nvz9/Y0nnnjC2LVrl7Fo0SLDy8vL+O///m937UKtqeyxmjNnjrF8+XLjxx9/NHbs2GE8/fTThiTjk08+cdcu1JqCggJj27ZtxrZt2wxJxuzZs41t27YZ//u//2sYBufVH1X2WFn5vPrrX/9q2O12Y82aNYbD4TCnkydPmjWcW7+ryrGy6rk1ZcoUY926dUZ2draxfft245lnnjHq1atnrFixwjCMunNOEYhqwRtvvGE0bdrU8Pb2Nq6//nqX1zKHDx9u3HLLLS71a9asMa677jrD29vbaNasmbFw4cJa7th9KnOsXnnlFePqq682fH19jaCgIKNbt27GF1984Yaua9/513cvnIYPH24YBufVH1X2WFn5vCrrOEkykpOTzRrOrd9V5VhZ9dwaOXKk+c/1Ro0aGT179jTDkGHUnXPKZhj//0klAAAAi+IZIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgBXlO7duysxMbHGt2Oz2fTZZ5/V+HYA1A4CEQBcRFJSkq699lp3twGghhGIAACA5RGIAFy2Tpw4oQceeEABAQGKjIzU66+/7rK+uLhYkydP1lVXXaX69eurc+fOWrNmjbk+JSVFDRs21GeffaZWrVrJ19dXvXv31sGDB83106ZN03/+8x/ZbDbZbDalpKSY448ePao777xT/v7+atmypT7//PPa2G0ANYBABOCy9eSTT2r16tVavny5VqxYoTVr1igzM9Nc/+CDD+q7775Tamqqtm/frrvvvlv9+vXT3r17zZqTJ0/qpZde0uLFi/Xdd98pPz9f99xzjyRp6NChmjhxotq1ayeHwyGHw6GhQ4eaY6dNm6YhQ4Zo+/btuu2223Tffffpt99+q70DAKD6GABwGSooKDC8vb2N1NRUc9mxY8cMPz8/4/HHHzf27dtn2Gw245dffnEZ17NnT2PKlCmGYRhGcnKyIcnIyMgw1+/evduQZGzatMkwDMOYOnWq0aFDh1Lbl2T87W9/M+cLCwsNm81mfPXVV9W5mwBqiaeb8xgAVMlPP/2k4uJixcfHm8uCg4MVGxsrSfr3v/8twzDUqlUrl3FFRUUKCQkx5z09PdWpUydzvnXr1mrYsKF2796tG2+88aI9XHPNNebf9evXV2BgoHJzc//UfgFwDwIRgMuSYRgXXX/u3Dl5eHgoMzNTHh4eLusCAgJc5m02W6nxZS27kJeXV6kx586du+Q4AHUPzxABuCy1aNFCXl5eysjIMJc5nU79+OOPkqTrrrtOJSUlys3NVYsWLVymiIgIc8zZs2e1detWc37Pnj06fvy4WrduLUny9vZWSUlJLe0VAHchEAG4LAUEBGjUqFF68skntWrVKu3YsUMjRoxQvXq//2OtVatWuu+++/TAAw/o008/VXZ2trZs2aJXXnlFX375pfk5Xl5eGjdunDZt2qR///vfevDBB9WlSxfzdlmzZs2UnZ2trKwsHT16VEVFRW7ZXwA1i0AE4LL16quv6uabb9bAgQPVq1cvdevWTR07djTXJycn64EHHtDEiRMVGxurgQMHatOmTYqOjjZr/P399dRTT2nYsGGKj4+Xn5+fUlNTzfV33XWX+vXrpx49eqhRo0b6xz/+Uav7CKB22IxL3YgHgCtUSkqKEhMTdfz4cXe3AsDNuEIEAAAsj0AEAAAsj1tmAADA8rhCBAAALI9ABAAALI9ABAAALI9ABAAALI9ABAAALI9ABAAALI9ABAAALI9ABAAALO//AYzVhOoLYXCTAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_depth_dist(df):\n",
    "    fig, ax = plt.subplots()\n",
    "    sns.histplot(\n",
    "        data=df.melt(id_vars=\"query\", value_vars=[\"query_depth\", \"ctx_depth\"], var_name=\"type\", value_name=\"depth\"), \n",
    "        x=\"depth\",\n",
    "        multiple='dodge',\n",
    "        hue=\"type\",\n",
    "        ax=ax\n",
    "    )\n",
    "plot_depth_dist(df)\n",
    "# Should we try to even this out more?"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Augment with intent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def interleave_datasets(df1, df2):\n",
    "    # Ensure df1 and df2 have the same number of rows\n",
    "    min_rows = min(len(df1), len(df2))\n",
    "    df1 = df1.iloc[:min_rows]\n",
    "    df2 = df2.iloc[:min_rows]\n",
    "    \n",
    "    # Create a temporary key for sorting\n",
    "    df1['temp_key'] = np.arange(len(df1)) * 2\n",
    "    df2['temp_key'] = np.arange(len(df2)) * 2 + 1\n",
    "    \n",
    "    # Concatenate and sort\n",
    "    result = pd.concat([df1, df2]).sort_values('temp_key').reset_index(drop=True)\n",
    "    \n",
    "    # Remove the temporary key\n",
    "    return result.drop('temp_key', axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/scratch/tmp.9123616.kevidu/ipykernel_1841016/855790394.py:8: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df1['temp_key'] = np.arange(len(df1)) * 2\n",
      "/scratch/tmp.9123616.kevidu/ipykernel_1841016/855790394.py:9: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  df2['temp_key'] = np.arange(len(df2)) * 2 + 1\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>query_no_mod</th>\n",
       "      <th>query</th>\n",
       "      <th>prior_answer</th>\n",
       "      <th>context</th>\n",
       "      <th>ctx_answer</th>\n",
       "      <th>query_depth</th>\n",
       "      <th>ctx_depth</th>\n",
       "      <th>weight_context</th>\n",
       "      <th>answer</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>(2 * 4) - 3</td>\n",
       "      <td>(2 * 4) - 3 =</td>\n",
       "      <td>5</td>\n",
       "      <td>(2 * 4) - 3 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>(2 * 4) - 3</td>\n",
       "      <td>(2 * 4) - 3 =</td>\n",
       "      <td>5</td>\n",
       "      <td>(2 * 4) - 3 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 + 0</td>\n",
       "      <td>2 + 0 =</td>\n",
       "      <td>2</td>\n",
       "      <td>0 = 4</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2 + 0</td>\n",
       "      <td>2 + 0 =</td>\n",
       "      <td>2</td>\n",
       "      <td>0 = 4</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1 * 6</td>\n",
       "      <td>1 * 6 =</td>\n",
       "      <td>6</td>\n",
       "      <td>1 * 6 = 4</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9995</th>\n",
       "      <td>((4 * 0) - 0) * 0</td>\n",
       "      <td>((4 * 0) - 0) * 0 =</td>\n",
       "      <td>0</td>\n",
       "      <td>((4 * 0) - 0) * 0 = 3</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9996</th>\n",
       "      <td>((0 - 0) + 7) - 3</td>\n",
       "      <td>((0 - 0) + 7) - 3 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 - 0) + 7) - 3 = 0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9997</th>\n",
       "      <td>((0 - 0) + 7) - 3</td>\n",
       "      <td>((0 - 0) + 7) - 3 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 - 0) + 7) - 3 = 0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9998</th>\n",
       "      <td>((0 * 9) + 4) * 1</td>\n",
       "      <td>((0 * 9) + 4) * 1 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 * 9) + 4) * 1 = 5</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9999</th>\n",
       "      <td>((0 * 9) + 4) * 1</td>\n",
       "      <td>((0 * 9) + 4) * 1 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 * 9) + 4) * 1 = 5</td>\n",
       "      <td>5</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>10000 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           query_no_mod                query prior_answer  \\\n",
       "0           (2 * 4) - 3        (2 * 4) - 3 =            5   \n",
       "1           (2 * 4) - 3        (2 * 4) - 3 =            5   \n",
       "2                 2 + 0              2 + 0 =            2   \n",
       "3                 2 + 0              2 + 0 =            2   \n",
       "4                 1 * 6              1 * 6 =            6   \n",
       "...                 ...                  ...          ...   \n",
       "9995  ((4 * 0) - 0) * 0  ((4 * 0) - 0) * 0 =            0   \n",
       "9996  ((0 - 0) + 7) - 3  ((0 - 0) + 7) - 3 =            4   \n",
       "9997  ((0 - 0) + 7) - 3  ((0 - 0) + 7) - 3 =            4   \n",
       "9998  ((0 * 9) + 4) * 1  ((0 * 9) + 4) * 1 =            4   \n",
       "9999  ((0 * 9) + 4) * 1  ((0 * 9) + 4) * 1 =            4   \n",
       "\n",
       "                    context ctx_answer  query_depth  ctx_depth  \\\n",
       "0           (2 * 4) - 3 = 9          9            2          2   \n",
       "1           (2 * 4) - 3 = 9          9            2          2   \n",
       "2                     0 = 4          6            1          0   \n",
       "3                     0 = 4          6            1          0   \n",
       "4                 1 * 6 = 4          4            1          1   \n",
       "...                     ...        ...          ...        ...   \n",
       "9995  ((4 * 0) - 0) * 0 = 3          3            3          3   \n",
       "9996  ((0 - 0) + 7) - 3 = 0          0            3          3   \n",
       "9997  ((0 - 0) + 7) - 3 = 0          0            3          3   \n",
       "9998  ((0 * 9) + 4) * 1 = 5          5            3          3   \n",
       "9999  ((0 * 9) + 4) * 1 = 5          5            3          3   \n",
       "\n",
       "      weight_context answer  \n",
       "0                  0      5  \n",
       "1                  1      9  \n",
       "2                  0      2  \n",
       "3                  1      6  \n",
       "4                  0      6  \n",
       "...              ...    ...  \n",
       "9995               1      3  \n",
       "9996               0      4  \n",
       "9997               1      0  \n",
       "9998               0      4  \n",
       "9999               1      5  \n",
       "\n",
       "[10000 rows x 9 columns]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_prior = df.copy()\n",
    "df_prior[\"weight_context\"] = 0\n",
    "df_prior[\"answer\"] = df_prior[\"prior_answer\"]\n",
    "\n",
    "df_ctx = df.copy()\n",
    "df_ctx[\"weight_context\"] = 1\n",
    "df_ctx[\"answer\"] = df_ctx[\"ctx_answer\"]\n",
    "\n",
    "df_all = interleave_datasets(df_prior, df_ctx)\n",
    "# df_all = pd.concat([df_prior, df_ctx], axis=0)\n",
    "# df_all.sort_values([\"query\", \"context\"])\n",
    "\n",
    "df_all[\"answer\"] = df_all[\"answer\"].apply(str)\n",
    "df_all[\"prior_answer\"] = df_all[\"prior_answer\"].apply(str)\n",
    "df_all[\"ctx_answer\"] = df_all[\"ctx_answer\"].apply(str)\n",
    "df_all"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Train/val/test split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 6400 entries, 0 to 6399\n",
      "Data columns (total 9 columns):\n",
      " #   Column          Non-Null Count  Dtype \n",
      "---  ------          --------------  ----- \n",
      " 0   query_no_mod    6400 non-null   object\n",
      " 1   query           6400 non-null   object\n",
      " 2   prior_answer    6400 non-null   object\n",
      " 3   context         6400 non-null   object\n",
      " 4   ctx_answer      6400 non-null   object\n",
      " 5   query_depth     6400 non-null   int64 \n",
      " 6   ctx_depth       6400 non-null   int64 \n",
      " 7   weight_context  6400 non-null   int64 \n",
      " 8   answer          6400 non-null   object\n",
      "dtypes: int64(3), object(6)\n",
      "memory usage: 450.1+ KB\n",
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 1600 entries, 0 to 1599\n",
      "Data columns (total 9 columns):\n",
      " #   Column          Non-Null Count  Dtype \n",
      "---  ------          --------------  ----- \n",
      " 0   query_no_mod    1600 non-null   object\n",
      " 1   query           1600 non-null   object\n",
      " 2   prior_answer    1600 non-null   object\n",
      " 3   context         1600 non-null   object\n",
      " 4   ctx_answer      1600 non-null   object\n",
      " 5   query_depth     1600 non-null   int64 \n",
      " 6   ctx_depth       1600 non-null   int64 \n",
      " 7   weight_context  1600 non-null   int64 \n",
      " 8   answer          1600 non-null   object\n",
      "dtypes: int64(3), object(6)\n",
      "memory usage: 112.6+ KB\n",
      "<class 'pandas.core.frame.DataFrame'>\n",
      "RangeIndex: 2000 entries, 0 to 1999\n",
      "Data columns (total 9 columns):\n",
      " #   Column          Non-Null Count  Dtype \n",
      "---  ------          --------------  ----- \n",
      " 0   query_no_mod    2000 non-null   object\n",
      " 1   query           2000 non-null   object\n",
      " 2   prior_answer    2000 non-null   object\n",
      " 3   context         2000 non-null   object\n",
      " 4   ctx_answer      2000 non-null   object\n",
      " 5   query_depth     2000 non-null   int64 \n",
      " 6   ctx_depth       2000 non-null   int64 \n",
      " 7   weight_context  2000 non-null   int64 \n",
      " 8   answer          2000 non-null   object\n",
      "dtypes: int64(3), object(6)\n",
      "memory usage: 140.8+ KB\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(None, None, None)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_df, val_df, test_df = partition_df(df_all, columns=[\"query\"])\n",
    "# train_df = train_df.sort_values([\"query\", \"context\"])\n",
    "# val_df = val_df.sort_values([\"query\", \"context\"])\n",
    "# test_df = test_df.sort_values([\"query\", \"context\"])\n",
    "\n",
    "train_df.info(), val_df.info(), test_df.info()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "weight_context\n",
       "0    3200\n",
       "1    3200\n",
       "Name: count, dtype: int64"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_df.value_counts(\"weight_context\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>query_no_mod</th>\n",
       "      <th>query</th>\n",
       "      <th>prior_answer</th>\n",
       "      <th>context</th>\n",
       "      <th>ctx_answer</th>\n",
       "      <th>query_depth</th>\n",
       "      <th>ctx_depth</th>\n",
       "      <th>weight_context</th>\n",
       "      <th>answer</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>(2 * 4) - 3</td>\n",
       "      <td>(2 * 4) - 3 =</td>\n",
       "      <td>5</td>\n",
       "      <td>(2 * 4) - 3 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>(2 * 4) - 3</td>\n",
       "      <td>(2 * 4) - 3 =</td>\n",
       "      <td>5</td>\n",
       "      <td>(2 * 4) - 3 = 9</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2 + 0</td>\n",
       "      <td>2 + 0 =</td>\n",
       "      <td>2</td>\n",
       "      <td>0 = 4</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2 + 0</td>\n",
       "      <td>2 + 0 =</td>\n",
       "      <td>2</td>\n",
       "      <td>0 = 4</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1 * 6</td>\n",
       "      <td>1 * 6 =</td>\n",
       "      <td>6</td>\n",
       "      <td>1 * 6 = 4</td>\n",
       "      <td>4</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6395</th>\n",
       "      <td>((7 + 2) - 4) + 2</td>\n",
       "      <td>((7 + 2) - 4) + 2 =</td>\n",
       "      <td>7</td>\n",
       "      <td>2 = 3</td>\n",
       "      <td>9</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6396</th>\n",
       "      <td>((8 - 1) - 3) * 2</td>\n",
       "      <td>((8 - 1) - 3) * 2 =</td>\n",
       "      <td>8</td>\n",
       "      <td>(8 - 1) = 6</td>\n",
       "      <td>6</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6397</th>\n",
       "      <td>((8 - 1) - 3) * 2</td>\n",
       "      <td>((8 - 1) - 3) * 2 =</td>\n",
       "      <td>8</td>\n",
       "      <td>(8 - 1) = 6</td>\n",
       "      <td>6</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6398</th>\n",
       "      <td>((0 - 0) + 7) - 3</td>\n",
       "      <td>((0 - 0) + 7) - 3 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 - 0) + 7) - 3 = 0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6399</th>\n",
       "      <td>((0 - 0) + 7) - 3</td>\n",
       "      <td>((0 - 0) + 7) - 3 =</td>\n",
       "      <td>4</td>\n",
       "      <td>((0 - 0) + 7) - 3 = 0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6400 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "           query_no_mod                query prior_answer  \\\n",
       "0           (2 * 4) - 3        (2 * 4) - 3 =            5   \n",
       "1           (2 * 4) - 3        (2 * 4) - 3 =            5   \n",
       "2                 2 + 0              2 + 0 =            2   \n",
       "3                 2 + 0              2 + 0 =            2   \n",
       "4                 1 * 6              1 * 6 =            6   \n",
       "...                 ...                  ...          ...   \n",
       "6395  ((7 + 2) - 4) + 2  ((7 + 2) - 4) + 2 =            7   \n",
       "6396  ((8 - 1) - 3) * 2  ((8 - 1) - 3) * 2 =            8   \n",
       "6397  ((8 - 1) - 3) * 2  ((8 - 1) - 3) * 2 =            8   \n",
       "6398  ((0 - 0) + 7) - 3  ((0 - 0) + 7) - 3 =            4   \n",
       "6399  ((0 - 0) + 7) - 3  ((0 - 0) + 7) - 3 =            4   \n",
       "\n",
       "                    context ctx_answer  query_depth  ctx_depth  \\\n",
       "0           (2 * 4) - 3 = 9          9            2          2   \n",
       "1           (2 * 4) - 3 = 9          9            2          2   \n",
       "2                     0 = 4          6            1          0   \n",
       "3                     0 = 4          6            1          0   \n",
       "4                 1 * 6 = 4          4            1          1   \n",
       "...                     ...        ...          ...        ...   \n",
       "6395                  2 = 3          9            3          0   \n",
       "6396            (8 - 1) = 6          6            3          1   \n",
       "6397            (8 - 1) = 6          6            3          1   \n",
       "6398  ((0 - 0) + 7) - 3 = 0          0            3          3   \n",
       "6399  ((0 - 0) + 7) - 3 = 0          0            3          3   \n",
       "\n",
       "      weight_context answer  \n",
       "0                  0      5  \n",
       "1                  1      9  \n",
       "2                  0      2  \n",
       "3                  1      6  \n",
       "4                  0      6  \n",
       "...              ...    ...  \n",
       "6395               1      9  \n",
       "6396               0      8  \n",
       "6397               1      6  \n",
       "6398               0      4  \n",
       "6399               1      0  \n",
       "\n",
       "[6400 rows x 9 columns]"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "full_dir = os.path.join(ROOT_DATA_DIR, \"splits\", \"base\")\n",
    "os.makedirs(full_dir, exist_ok=True)\n",
    "train_df.to_csv(\n",
    "    os.path.join(full_dir, \"train.csv\"),\n",
    "    index=False,\n",
    ")\n",
    "val_df.to_csv(\n",
    "    os.path.join(full_dir, \"val.csv\"),\n",
    "    index=False,\n",
    ")\n",
    "test_df.to_csv(\n",
    "    os.path.join(full_dir, \"test.csv\"),\n",
    "    index=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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P37cXD569GgNHTpU8+fPV1hYmNq3b6+5c+eqc+fOZfoTFRWll1566Yb9Li0t1ZQpU9SkSRMFBARo+vTpMgzDqcYwDC1YsEBt2rSRj4+Punbtqv/+7/82l6empspms+njjz9W165d5e3trejoaB06dMhc/sQTT8jhcMhms5lDDq44f/68xowZIz8/P7Vo0UIrV668Yb8BKyEQAag3nnvuOW3btk2bNm3S5s2blZqaqvT09Aq3P3/+vPr06aNGjRppx44d2rlzpxo1aqRBgwappKTErPv888+VmZmpLVu26O9//7vGjBmjr7/+2umt+gcPHtSBAwc0evToG2534cKFeuedd7R69Wrt3LlT//nPf7Rp0yanmj/+8Y9as2aNli9frq+++kp/+MMf9Nhjj2n79u1ljsGf//xn7du3T0FBQYqNjdXFixfVo0cPLVmyRI0bN1ZWVpaysrI0bdo0pz5069ZNBw4c0IQJE/T73/9e33zzTYWPHXCz45YZgHqhsLBQq1ev1rvvvqv+/ftLktauXavmzZtXeB3Jyclq0KCB3n77bfNN9WvWrFGTJk2UmppqPonasGFDvf322063ygYOHKg1a9borrvuMtv16tVLbdq0ueF2lyxZohkzZujhhx+WJL311lv67LPPzOXnzp3TokWL9MUXXygmJkaS1KZNG+3cuVMrVqxQr169zNrZs2eX2f9NmzZp+PDhstvtstlsCgkJKdOH+++/XxMmTJAkPf/881q8eLFSU1PVoUOHCh8/4GZGIAJQL3z//fcqKSkxA4P08xOklXmfWHp6ur777junV3dI0oULF/T999+b0507dy4zbmjcuHEaM2aMFi1aJDc3N23YsEELFy684TYdDoeysrKc+u3u7q5u3bqZt82+/vprXbhwwQw6V5SUlOiOO+5wmlfe/mdmZt6wH126dDH/vhKacnJybtgOsAoCEYB64eoxN+Wx2Wxl6i5evGj+ffnyZUVFRWnDhg1l2jZr1sz8u2HDhmWWP/DAA/Ly8tKmTZvk5eWl4uJi84rPr3X58mVJ0scff6xbbrnFaZmXl9cN29/o+46S5OHhUabNle0CIBABqCfatm0rDw8PpaWlmY/q5+Xl6dtvvzVvKTVr1kxZWVlmm6NHj+r8+f97r9Kdd96p9957T0FBQZX+PqG7u7tGjRqlNWvWyMvLS7/97W/l6+t7w3Z2u12hoaFKS0vTvffeK0m6dOmS0tPTdeedd0qSOnXqJC8vL504ccLp9lh5ytv/K7e9PD09VVpaWqn9AvAzAhEAJwVZx+vkNho1aqSxY8fqueeeU0BAgIKDgzVr1iw1aPB/z4bcd999WrZsmbp3767Lly/r+eefd7oy8uijj+pPf/qTHnzwQc2dO1fNmzfXiRMn9MEHH+i555674XikJ598Uh07dpQk/fOf/6xw35999lm99tprateunTp27KhFixY5vSvIz89P06ZN0x/+8AddvnxZPXv2VEFBgXbt2qVGjRpp1KhRZu3cuXOd9j8wMFBDhw6V9PMLGAsLC/X555+ra9eu8vX1rVBoA0AgAvD/BAYGysfHV3vemVMr2/Px8VVgYGCl2vzpT39SYWGhYmNj5efnp6lTp8rhcJjLFy5cqCeeeEL33nuvwsLCtHTpUqen0Hx9fbVjxw49//zzGjZsmM6ePatbbrlFffv2rdAVo3bt2qlHjx46c+aMoqOjK9zvqVOnKisrS6NHj1aDBg00ZswYPfTQQ059f/nllxUUFKT58+frf//3f9WkSRPdeeedmjlzptO6XnvtNT377LM6evSounbtqo8++sgc79SjRw89/fTTGjFihM6cOaPZs2df903/AP6PzajIjXmooKBAdrtdDoej0pfaa8qXX36pqKgopc/uqTtb2SvX9rhDUXN2Ol22hzVcuHBBx44dU+vWreXt7e20rD5+y6x37966/fbbtWTJkl/fqRswDEMdOnTQU089pSlTptT49n4pNTVVffr0UV5enpo0aVLj27veeQLUJxX995srRABMLVq04FMa15CTk6N169bpxx9/1BNPPOHq7gCoZgQiAKiA4OBgBQYGauXKlWratKnTskaNGl2z3aeffqp77rmnprsH4FciEAGo11JTU2tlO9cbXZCRkXHNZVc/Rl9VvXv3rtCrBwBUDYEIAH6ltm3buroLAH4lvmUGAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0HVAEz18cWMAFAdCEQAJP0chjp2iND5ogu1sj1fH29lfnOkXoWipKQkxcfHO32HrKaMHj1a+fn5+vDDD2t8WwAIRAD+n9zcXJ0vuqD1429Xx9Brv2iwOmRmFeqxlRnKzc2tlkB0/PhxtW7dWgcOHNDtt9/+6ztYi+pz34GbCYEIgJOOoY0q/W08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27r6P9/CwsJq/3f2yvoMw7h+oWEBP/74oyHJ+Oc//+k0/9VXXzXat29fbpvZs2cbkvjx48ePHz9+N8Hv5MmT180KlrhCdIXNZnOaNgyjzLwrZsyYoSlTppjTly9f1n/+8x8FBARcs01VFBQUKDw8XCdPnlTjxo2rbb03I45V5XC8Ko5jVXEcq4rjWFVcTR4rwzB09uxZhYWFXbfOEoEoMDBQbm5uZW5L5eTkKDg4uNw2Xl5e8vLycprXpEmTmuqiGjduzH9hKohjVTkcr4rjWFUcx6riOFYVV1PHym6337DGEoOqPT09FRUVpS1btjjN37Jli3r06OGiXgEAgLrCEleIJGnKlCmKi4tTt27dFBMTo5UrV+rEiRN6+umnXd01AADgYpYJRCNGjNCZM2c0d+5cZWVlKTIyUp988olatmzp0n55eXlp9uzZZW7PoSyOVeVwvCqOY1VxHKuK41hVXF04VjbDuNFzaAAAADc3S4whAgAAuB4CEQAAsDwCEQAAsDwCEQAAsDwCUS1488031bp1a3l7eysqKkr/+Mc/rlu/fft2RUVFydvbW23atNFbb71VSz11vcocq9TUVNlstjK/b775phZ77Bo7duzQAw88oLCwMNlsNn344Yc3bGPV86qyx8rK59X8+fN11113yc/PT0FBQRo6dKj5bavrseK5VZVjZdVza/ny5erSpYv50sWYmBh9+umn123jinOKQFTD3nvvPcXHx2vWrFk6cOCA7rnnHg0ePFgnTpwot/7YsWO6//77dc899+jAgQOaOXOmJk+erPfff7+We177Knusrjhy5IiysrLMX7t27Wqpx65z7tw5de3aVcuWLatQvZXPq8oeqyuseF5t375dzzzzjNLS0rRlyxZdunRJAwYM0Llz567ZxqrnVlWO1RVWO7eaN2+u1157Tfv379f+/ft133336cEHH9RXX31Vbr3Lzqlq+Xoqrunuu+82nn76aad5HTp0MF544YVy66dPn2506NDBad5TTz1ldO/evcb6WFdU9lht27bNkGTk5eXVQu/qLknGpk2brltj5fPqlypyrDiv/k9OTo4hydi+ffs1azi3flaRY8W59X+aNm1qvP322+Uuc9U5xRWiGlRSUqL09HQNGDDAaf6AAQO0a9euctvs3r27TP3AgQO1f/9+Xbx4scb66mpVOVZX3HHHHQoNDVXfvn21bdu2muxmvWXV8+rX4LySHA6HJMnf3/+aNZxbP6vIsbrCyudWaWmpkpOTde7cOcXExJRb46pzikBUg3Jzc1VaWlrmA7LBwcFlPjR7RXZ2drn1ly5dUm5ubo311dWqcqxCQ0O1cuVKvf/++/rggw8UERGhvn37aseOHbXR5XrFqudVVXBe/cwwDE2ZMkU9e/ZUZGTkNes4typ+rKx8bh06dEiNGjWSl5eXnn76aW3atEmdOnUqt9ZV55RlPt3hSjabzWnaMIwy825UX978m1FljlVERIQiIiLM6ZiYGJ08eVJ//vOfde+999ZoP+sjK59XlcF59bOJEyfq4MGD2rlz5w1rrX5uVfRYWfncioiIUEZGhvLz8/X+++9r1KhR2r59+zVDkSvOKa4Q1aDAwEC5ubmVucKRk5NTJv1eERISUm69u7u7AgICaqyvrlaVY1We7t276+jRo9XdvXrPqudVdbHaeTVp0iR99NFH2rZtm5o3b37dWqufW5U5VuWxyrnl6emptm3bqlu3bpo/f766du2qpUuXllvrqnOKQFSDPD09FRUVpS1btjjN37Jli3r06FFum5iYmDL1mzdvVrdu3eTh4VFjfXW1qhyr8hw4cEChoaHV3b16z6rnVXWxynllGIYmTpyoDz74QF988YVat259wzZWPbeqcqzKY5Vz62qGYai4uLjcZS47p2p0yDaM5ORkw8PDw1i9erXx9ddfG/Hx8UbDhg2N48ePG4ZhGC+88IIRFxdn1v/v//6v4evra/zhD38wvv76a2P16tWGh4eH8d///d+u2oVaU9ljtXjxYmPTpk3Gt99+axw+fNh44YUXDEnG+++/76pdqDVnz541Dhw4YBw4cMCQZCxatMg4cOCA8e9//9swDM6rX6rssbLyefX73//esNvtRmpqqpGVlWX+zp8/b9Zwbv2sKsfKqufWjBkzjB07dhjHjh0zDh48aMycOdNo0KCBsXnzZsMw6s45RSCqBW+88YbRsmVLw9PT07jzzjudHsscNWqU0atXL6f61NRU44477jA8PT2NVq1aGcuXL6/lHrtOZY7V66+/btx6662Gt7e30bRpU6Nnz57Gxx9/7IJe174rj+9e/Rs1apRhGJxXv1TZY2Xl86q84yTJWLNmjVnDufWzqhwrq55bY8aMMf93vVmzZkbfvn3NMGQYdeecshnG/xupBAAAYFGMIQIAAJZHIAIAAJZHIAIAAJZHIAIAAJZHIAIAAJZHIAIAAJZHIAIAAJZHIAIAAJZHIAJwU+ndu7fi4+NrfDs2m00ffvhhjW8HQO0gEAHAdSQkJOj22293dTcA1DACEQAAsDwCEYB669y5c3r88cfVqFEjhYaGauHChU7LS0pKNH36dN1yyy1q2LChoqOjlZqaai5PSkpSkyZN9OGHH6p9+/by9vZW//79dfLkSXP5nDlz9K9//Us2m002m01JSUlm+9zcXD300EPy9fVVu3bt9NFHH9XGbgOoAQQiAPXWc889p23btmnTpk3avHmzUlNTlZ6ebi5/4okn9M9//lPJyck6ePCgHnnkEQ0aNEhHjx41a86fP69XX31Va9eu1T//+U8VFBTot7/9rSRpxIgRmjp1qm677TZlZWUpKytLI0aMMNvOmTNHw4cP18GDB3X//ffr0Ucf1X/+85/aOwAAqo8BAPXQ2bNnDU9PTyM5Odmcd+bMGcPHx8d49tlnje+++86w2WzGjz/+6NSub9++xowZMwzDMIw1a9YYkoy0tDRzeWZmpiHJ2LNnj2EYhjF79myja9euZbYvyfjjH/9oThcWFho2m8349NNPq3M3AdQSdxfnMQCoku+//14lJSWKiYkx5/n7+ysiIkKS9OWXX8owDLVv396pXXFxsQICAsxpd3d3devWzZzu0KGDmjRposzMTN19993X7UOXLl3Mvxs2bCg/Pz/l5OT8qv0C4BoEIgD1kmEY111++fJlubm5KT09XW5ubk7LGjVq5DRts9nKtC9v3tU8PDzKtLl8+fIN2wGoexhDBKBeatu2rTw8PJSWlmbOy8vL07fffitJuuOOO1RaWqqcnBy1bdvW6RcSEmK2uXTpkvbv329OHzlyRPn5+erQoYMkydPTU6WlpbW0VwBchUAEoF5q1KiRxo4dq+eee06ff/65Dh8+rNGjR6tBg5//Z619+/Z69NFH9fjjj+uDDz7QsWPHtG/fPr3++uv65JNPzPV4eHho0qRJ2rNnj7788ks98cQT6t69u3m7rFWrVjp27JgyMjKUm5ur4uJil+wvgJpFIAJQb/3pT3/Svffeq9jYWPXr1089e/ZUVFSUuXzNmjV6/PHHNXXqVEVERCg2NlZ79uxReHi4WePr66vnn39eI0eOVExMjHx8fJScnGwuf/jhhzVo0CD16dNHzZo101/+8pda3UcAtcNm3OhGPADcpJKSkhQfH6/8/HxXdwWAi3GFCAAAWB6BCAAAWB63zAAAgOVxhQgAAFgegQgAAFgegQgAAFgegQgAAFgegQgAAFgegQgAAFgegQgAAFgegQgAAFje/w/VHynK0LIt/gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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de7cWV5eXurRo4e+/PJLc/njjz+uvLw82Ww28yGqKwoLCzVhwgT5+voqPDxc69atu27fN4tABABADZg1a5Z27dqlxMREbd++XcnJyUpNTa30+oWFherXr58aNmyo3bt3a8+ePWrYsKGGDBmikpISs27nzp1KS0tTUlKS/vGPf2jChAk6fvy4Dhw4YNYcOXJEhw4d0vjx46+73+XLl+utt97S+vXrtWfPHv38889KTEy0q3n++ecVFxentWvX6tixY3r22Wc1ZswYpaSklDsHf/rTn3TgwAE1a9ZMw4YN08WLF9WrVy+tWrVKfn5+yszMVGZmpmbOnGnXQ/fu3XXo0CFNmTJFv//97/XVV19V+txVBV+ZAQBQzQoKCrR+/Xr99a9/1cCBAyVJGzZsUPPmzSu9jYSEBLm4uOjNN980370ZFxenRo0aKTk52fxtvQYNGujNN9+0+6ps8ODBiouL0x133GGu16dPH7Vs2fK6+121apXmzp2r3/72t5Kk119/XR9++KG5/Pz581qxYoU++ugj9ezZU5LUsmVL7dmzR3/5y1/Up08fs3b+/Pnljj8xMVEjR46Uv7+/bDab+aqu/3bfffdpypQpkqTnnntOK1euVHJystq2bVvp83ejCEQAAFSzb7/9ViUlJWZgkC7/Jt6NvCEhNTVV33zzjd2PEUvShQsX9O2335qfO3bsWO6+oUmTJmnChAlasWKFXF1dtWnTJi1fvvy6+8zLy1NmZqZd325uburevbv5tdnx48d14cIFM+hcUVJSoq5du9rNq+j409LSrttHp06dzL+vhKbs7OzrrnczCEQAAFSza/3o8BU2m61c3cWLF82/y8rKFBUVpU2bNpVbt2nTpubfDRo0KLf8gQcekKenpxITE+Xp6ani4mLzis/NKisrkyT985//1C233GK3zNPT87rrX7nadS3u7u7l1rmy35pCIAIAoJq1atVK7u7u2rdvn/mYfm5urk6ePGl+pdS0aVNlZmaa63z99dcqLPy/31Xq1q2b3n33XTVr1kx+fn43tH83NzeNGzdOcXFx8vT01COPPCIfH5/rrufv76+QkBDt27dP99xzjyTp0qVLSk1NVbdu3SRJ7du3l6enpzIyMuy+HqtIRcd/5WsvDw8PlZaW3tBx1SQCEQCgzsrPPOWU+2nYsKEmTpyoWbNmKSAgQEFBQZo3b55cXP7vWaZf//rXWrNmje666y6VlZXpueees7syMnr0aL3yyit68MEHtXDhQjVv3lwZGRnasmWLZs2add37kZ544gm1a9dOkvTJJ59UuvdnnnlGL7/8siIjI9WuXTutWLHC7reCfH19NXPmTD377LMqKytT7969lZ+fr71796phw4YaN26cWbtw4UK74w8MDNTw4cMlXf4BxoKCAu3cuVOdO3eWj49PpUJbTSEQAQDqnMDAQHl7+2j/WwtqbZ/e3j4KDAysdP0rr7yigoICDRs2TL6+vpoxY4by8vLM5cuXL9fjjz+ue+65R6GhoVq9erXdU2g+Pj7avXu3nnvuOY0YMULnzp3TLbfcov79+1fqilFkZKR69eqln376ST169Kh03zNmzFBmZqbGjx8vFxcXTZgwQb/5zW/sen/ppZfUrFkzLVmyRP/+97/VqFEjdevWTX/4wx/stvXyyy/rmWee0ddff63OnTtr69at5v1OvXr10pNPPqmHH35YP/30k+bPn3/Nd5fWNJtRmS86ofz8fPn7+ysvL++GL13Whs8//1xRUVFKnd9b3Vr4V20bp/IUtWCP3aVRAHCkCxcuKD09XREREfLy8rJbVhffZda3b1916dJFq1atqp6mrsEwDLVt21aTJ0/W9OnTa3x//y05OVn9+vVTbm6uGjVqVOP7u9Y4qey/31whAgDUSeHh4bxG4yqys7P19ttv68yZM3r88ccd3U6dQCACAKCeCQoKUmBgoNatW6fGjRvbLWvYsOFV1/vggw90991313R7TolABABALUlOTq6V/VzrbpjDhw9fddkvH6Ovqr59+1bqpwecCYEIAAALadWqlaNbcEq8ywwAAFgegQgAAFgegQgAAFgegQgAAFgeN1UDAOqkuvjDjHBeBCIAQJ2TkZGhdm3bqLDoQq3t08fbS2lfnagzoSg+Pl7R0dF27yGrKePHj9fZs2f1/vvv1/i+agqBCABQ5+Tk5Kiw6II2/q6L2oVc/YcGq0taZoHGrDusnJycmw5Ep06dUkREhA4dOqQuXbpUT4O1pC73fj0EIgBAndUupGGV398I/DduqgYAoAaUlZVp6dKlatWqlTw9PRUeHq5FixYpIiJCktS1a1fZbDb17dtXFy5c0O23367f/e535vrp6eny9/fXG2+8Uan9xcfHKzw8XD4+PvrNb36jn376qVzN//7v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LEw7duzQ4MGDK9x3cXGxiouLzc/5+fk1eagAAMCBnPoKUe/evbVz506dPHlSkvTFF19oz549uu+++yRJ6enpysrK0qBBg8x1PD091adPH+3du1eSlJqaqosXL9rVhIaGqkOHDmZNRZYsWSJ/f39zCgsLq4lDBAAATsCprxA999xzysvLU9u2beXq6qrS0lItWrRIjz76qCQpKytLkhQUFGS3XlBQkL777juzxsPDQ40bNy5Xc2X9isydO1fTp083P+fn5xOKAACop5w6EL377rvauHGjNm/erNtvv12HDx9WdHS0QkNDNW7cOLPOZrPZrWcYRrl5v3S9Gk9PT3l6et7cAQAAgDrBqQPRrFmzNGfOHD3yyCOSpI4dO+q7777TkiVLNG7cOAUHB0u6fBUoJCTEXC87O9u8ahQcHKySkhLl5ubaXSXKzs5Wr169avFoAACAs3Lqe4gKCwvl4mLfoqurq/nYfUREhIKDg5WUlGQuLykpUUpKihl2oqKi5O7ubleTmZmpo0ePEogAAIAkJ79C9MADD2jRokUKDw/X7bffrkOHDmnFihWaMGGCpMtflUVHR2vx4sWKjIxUZGSkFi9eLB8fH40aNUqS5O/vr4kTJ2rGjBkKCAhQkyZNNHPmTHXs2NF86gwAAFibUwei2NhYvfDCC5oyZYqys7MVGhqqyZMn68UXXzRrZs+eraKiIk2ZMkW5ubnq0aOHtm/fLl9fX7Nm5cqVcnNz08iRI1VUVKT+/fsrPj5erq6ujjgsAADgZJw6EPn6+mrVqlVatWrVVWtsNptiYmIUExNz1RovLy/Fxsba/aAjAADAFU59DxEAAEBtIBABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLIxABAADLc3N0AwCA6peRkaGcnJyb2kZgYKDCw8OrqSPAuRGIAKCeycjIUNu27VRUVHhT2/H29tFXX6URimAJBCIAqGdycnJUVFSoHhPmyy+kRZW2kZ95SvvfWqCcnBwCESyBQAQA9ZRfSAs1CW/j6DaAOoGbqgEAgOURiAAAgOURiAAAgOURiAAAgOURiAAA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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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8MEHio6Olqenp1q0aKE5c+bo/Pnz5nybzaaVK1dq0KBB8vLyUnh4uP72t7+Z8yvq/b+9+uqrCg4Olr+/v5544gmVlJRUen8BV5Kenq7IyDaKjo6+piEyso3S09OdvTnXhDNEAOqMGTNm6I033tCSJUvUvXt3ZWRk6NixY/riiy90++23a+vWrbrlllvk7u4uT09PbdiwQV26dNFdd92le+65RyNHjlTv3r01bty4K/7W3r17NWbMGM2bN09Dhw7V5s2bNXv2bIeajz/+WCNGjNCf//xn9ejRQ99++60ZwP67dtasWXr55Ze1bNkyrVu3Tg899JCioqLUpk2bCnu/aPv27QoODtb27dt14sQJPfDAA+rQoUOl+gcqIzs7W4WFBeoyZrZ8g5tXaR15GSe196051XYJ3FkIRADqhDNnzmjZsmVavny5Ro0aJUm6+eab1b17d508eVKS5O/vr6CgIHOZDh066MUXX9S4ceP00EMP6dtvv630TcrLli3TgAEDNH36dElSq1attHv3bm3evNmseemllzR9+nSznxYtWuiFF17Q1KlTHQLR/fffr8cee0yS9MILLygpKUlxcXFasWKFmjZtWmHvktSkSRMtX75cLi4uioyM1N13361t27YRiFDtfIObyy+stbPbcCoumQGoE1JTU1VUVKQ+ffpc1XKTJ09W69atFRcXpzVr1iggIKDSv9e1a1eHab8eT0lJ0dy5c9WoUSNzGDdunDIyMlRQUHDJ5bp27arU1NQr9nDLLbfIxcXFHA8ODlZWVlal+gdwdThDBKBO8PLyqtJyWVlZOn78uFxcXPTNN99o4MCBlVquMl+WLysr05w5czR06NBy8zw9PS+7rM1mu+L63dzcyi1TVlZ2xeUAXD3OEAGoEyIiIuTl5aVt27aVm3fxvpvS0tJy88aMGaOoqCj99a9/1dSpU/XVV19V6vfatm2rPXv2OEz79XinTp10/PhxtWzZstzQoEGDSy63Z88eRUZGXrF3ADWHM0QAHKRm5NfK3/D09NS0adM0depUubu76ze/+Y1++uknHT16VKNGjZKXl5c2b96sG2+8UZ6enrLb7Xrttdf0+eef6/DhwwoNDdVHH32khx9+WHv37nW4ebkiTz31lLp166aFCxfqvvvu05YtWxzuH5Kk559/XoMHD1ZoaKjuv/9+NWjQQIcPH9aXX36pF1980az729/+ps6dO6t79+7asGGDvvjiC61evVqS1KxZswp7B1CzCEQAJF14j4i3l6dGrDpUI7/n7eVZ6ft5Lpo1a5ZcXV31/PPP68cff1RwcLAef/xxubq66s9//rPmzp2r559/Xj169NDrr7+uZ599VqtXr1ZoaKgk6bXXXlP79u01a9YsLViw4LK/dccdd+jNN9/U7NmzFRsbq759++q5557TCy+8YNYMGDBAH374oebOnauFCxfKzc1NkZGR5g3UF82ZM0cJCQmaMGGCgoKCtGHDBrVt21aSKuw9OTn5qvYLgGtnMypzoRzKy8uT3W5Xbm6ufH19nd1OOQcOHFB0dLRSZnev8kv1DpzMVfScXUpJSVGnTp2quUPUFufOnVNaWprCw8PL3efCt8yqn81mU2Jiou677z5nt3JVLnecoP64+Lej38w1VX7K7Jf040p66dFa+7ejsn+/OUMEwBQWFmaJkAIAv8ZN1QAsadCgQQ6Py//3MG/ePGe3B6CGcYYIgCW9+eabKiwsrHCen59ftf0OdyUAdQOBCIAl3XDDDc5uAUAtwiUzwKJ4wR8uh+MDVsMZIsBi3N3d1aBBA/34449q2rSp3N3dK/XWZFiDYRgqLi7WTz/9pAYNGlzxfU1AfUEgAiymQYMGCg8PV0ZGhn788Udnt4NaytvbW2FhYQ5v3AbqMwIRYEHu7u4KCwvT+fPn+WQEynFxcZGrqytnDmEpBCLAomw2m9zc3Mp9QBQArIhzoQAAwPIIRAAAwPIIRAAAwPIIRAAAwPKcGoh27type+65RyEhIbLZbHr//fcd5huGodjYWIWEhMjLy0u9evXS0aNHHWqKioo0ceJEBQQEqGHDhhoyZIi+//57h5qcnByNHDlSdrtddrtdI0eO1OnTp6/z1gEAgLrCqYHo7Nmzat++vZYvX17h/IULF2rx4sVavny59u3bp6CgIPXr109nzpwxa2JiYpSYmKiEhATt2rVL+fn5Gjx4sMOjxMOHD9ehQ4e0efNmbd68WYcOHdLIkSOv+/YBAIC6wamP3Q8aNEiDBg2qcJ5hGFq6dKlmzpypoUOHSpLWrl2rwMBAbdy4UePHj1dubq5Wr16tdevWqW/fvpKk9evXKzQ0VFu3btWAAQOUmpqqzZs3a8+ePerSpYsk6Y033lDXrl11/PhxtW7dumY2FgAA1Fq19h6itLQ0ZWZmqn///uY0Dw8P9ezZU7t375YkpaSkqKSkxKEmJCREUVFRZs3nn38uu91uhiFJuuOOO2S3282aihQVFSkvL89hAAAA9VOtDUSZmZmSpMDAQIfpgYGB5rzMzEy5u7urSZMml61p1qxZufU3a9bMrKnI/PnzzXuO7Ha7QkNDr2l7AABA7VVrA9FFv351vGEYV3yd/K9rKqq/0npmzJih3Nxcczh16tRVdg4AAOqKWhuIgoKCJKncWZysrCzzrFFQUJCKi4uVk5Nz2Zr//Oc/5db/008/lTv79N88PDzk6+vrMAAAgPqp1gai8PBwBQUFKSkpyZxWXFysHTt2qFu3bpKk6Ohoubm5OdRkZGToyJEjZk3Xrl2Vm5urL774wqzZu3evcnNzzRoAAGBtTn3KLD8/XydOnDDH09LSdOjQIfn5+SksLEwxMTGaN2+eIiIiFBERoXnz5snb21vDhw+XJNntdo0dO1aTJ0+Wv7+//Pz8NGXKFLVr18586qxNmzYaOHCgxo0bp7/85S+SpD/84Q8aPHgwT5gBAABJTg5E+/fvV+/evc3xSZMmSZJGjRql+Ph4TZ06VYWFhZowYYJycnLUpUsXbdmyRT4+PuYyS5Yskaurq4YNG6bCwkL16dNH8fHxcnFxMWs2bNigp556ynwabciQIZd89xEAALAepwaiXr16yTCMS8632WyKjY1VbGzsJWs8PT0VFxenuLi4S9b4+flp/fr119IqAACox2rtPUQAAAA1hUAEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsj0AEAAAsz9XZDQAAql96erqys7OvaR0BAQEKCwurpo6A2o1ABAD1THp6uiIj26iwsOCa1uPl5a1jx1IJRbAEAhEA1DPZ2dkqLCxQlzGz5RvcvErryMs4qb1vzVF2djaBCJZAIAKAeso3uLn8wlo7uw2gTuCmagAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHkEIgAAYHm1OhCdP39ezz33nMLDw+Xl5aUWLVpo7ty5KisrM2sMw1BsbKxCQkLk5eWlXr166ejRow7rKSoq0sSJExUQEKCGDRtqyJAh+v7772t6cwAAQC1VqwPRggUL9Prrr2v58uVKTU3VwoUL9corryguLs6sWbhwoRYvXqzly5dr3759CgoKUr9+/XTmzBmzJiYmRomJiUpISNCuXbuUn5+vwYMHq7S01BmbBQAAapla/abqzz//XPfee6/uvvtuSVLz5s319ttva//+/ZIunB1aunSpZs6cqaFDh0qS1q5dq8DAQG3cuFHjx49Xbm6uVq9erXXr1qlv376SpPXr1ys0NFRbt27VgAEDnLNxAACg1qjVZ4i6d++ubdu26euvv5Yk/etf/9KuXbt01113SZLS0tKUmZmp/v37m8t4eHioZ8+e2r17tyQpJSVFJSUlDjUhISGKiooyaypSVFSkvLw8hwEAANRPtfoM0bRp05Sbm6vIyEi5uLiotLRUL730kh566CFJUmZmpiQpMDDQYbnAwEB99913Zo27u7uaNGlSrubi8hWZP3++5syZU52bAwAAaqlafYbonXfe0fr167Vx40YdOHBAa9eu1auvvqq1a9c61NlsNodxwzDKTfu1K9XMmDFDubm55nDq1KmqbwgAAKjVavUZomeffVbTp0/Xgw8+KElq166dvvvuO82fP1+jRo1SUFCQpAtngYKDg83lsrKyzLNGQUFBKi4uVk5OjsNZoqysLHXr1u2Sv+3h4SEPD4/rsVkAAKCWqdVniAoKCtSggWOLLi4u5mP34eHhCgoKUlJSkjm/uLhYO3bsMMNOdHS03NzcHGoyMjJ05MiRywYiAABgHbX6DNE999yjl156SWFhYbrlllt08OBBLV68WGPGjJF04VJZTEyM5s2bp4iICEVERGjevHny9vbW8OHDJUl2u11jx47V5MmT5e/vLz8/P02ZMkXt2rUznzoDAADWVqsDUVxcnGbNmqUJEyYoKytLISEhGj9+vJ5//nmzZurUqSosLNSECROUk5OjLl26aMuWLfLx8TFrlixZIldXVw0bNkyFhYXq06eP4uPj5eLi4ozNAgAAtUytDkQ+Pj5aunSpli5deskam82m2NhYxcbGXrLG09NTcXFxDi90BAAAuKhW30MEAABQEwhEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8ghEAADA8qoUiFq0aKGff/653PTTp0+rRYsW19wUAABATapSIDp58qRKS0vLTS8qKtIPP/xwzU0BAADUJNerKd60aZP5748//lh2u90cLy0t1bZt29S8efNqaw4AAKAmXFUguu+++yRJNptNo0aNcpjn5uam5s2ba9GiRdXWHAAAQE24qkBUVlYmSQoPD9e+ffsUEBBwXZoCAACoSVcViC5KS0ur7j4AAACcpkqBSJK2bdumbdu2KSsryzxzdNFbb711zY0BAADUlCoFojlz5mju3Lnq3LmzgoODZbPZqrsvAACAGlOlQPT6668rPj5eI0eOrO5+AAAAalyV3kNUXFysbt26VXcvAAAATlGlQPTYY49p48aN1d0LAACAU1Tpktm5c+e0atUqbd26Vbfeeqvc3Nwc5i9evLhamgMAAKgJVQpEhw8fVocOHSRJR44ccZjHDdYAAKCuqVIg2r59e3X3AQAA4DRVuocIAACgPqnSGaLevXtf9tLYJ598UuWGAAAAalqVAtHF+4cuKikp0aFDh3TkyJFyH30FAACo7aoUiJYsWVLh9NjYWOXn519TQwAAADWtWu8hGjFiBN8xAwAAdU61BqLPP/9cnp6e1blKAACA665Kl8yGDh3qMG4YhjIyMrR//37NmjWrWhoDAACoKVUKRHa73WG8QYMGat26tebOnav+/ftXS2MAAAA1pUqBaM2aNdXdBwAAgNNUKRBdlJKSotTUVNlsNrVt21YdO3asrr4AAABqTJUCUVZWlh588EElJyercePGMgxDubm56t27txISEtS0adPq7hMAAOC6qdJTZhMnTlReXp6OHj2qX375RTk5OTpy5Ijy8vL01FNPVXePAAAA11WVzhBt3rxZW7duVZs2bcxpbdu21WuvvcZN1QAAoM6p0hmisrIyubm5lZvu5uamsrKya24KAACgJlUpEP32t7/V008/rR9//NGc9sMPP+iZZ55Rnz59qq25i+sdMWKE/P395e3trQ4dOiglJcWcbxiGYmNjFRISIi8vL/Xq1UtHjx51WEdRUZEmTpyogIAANWzYUEOGDNH3339frX0CAIC6q0qBaPny5Tpz5oyaN2+um2++WS1btlR4eLjOnDmjuLi4amsuJydHv/nNb+Tm5qaPPvpIX331lRYtWqTGjRubNQsXLtTixYu1fPly7du3T0FBQerXr5/OnDlj1sTExCgxMVEJCQnatWuX8vPzNXjwYJWWllZbrwAAoO6q0j1EoaGhOnDggJKSknTs2DEZhqG2bduqb9++1drcggULFBoa6vDeo+bNm5v/NgxDS5cu1cyZM823Z69du1aBgYHauHGjxo8fr9zcXK1evVrr1q0z+1u/fr1CQ0O1detWDRgwoFp7BgAAdc9VnSH65JNP1LZtW+Xl5UmS+vXrp4kTJ+qpp57SbbfdpltuuUWffvpptTW3adMmde7cWffff7+aNWumjh076o033jDnp6WlKTMz0+FGbg8PD/Xs2VO7d++WdOFdSSUlJQ41ISEhioqKMmsqUlRUpLy8PIcBAADUT1cViJYuXapx48bJ19e33Dy73a7x48dr8eLF1dbcv//9b61cuVIRERH6+OOP9fjjj+upp57SX//6V0lSZmamJCkwMNBhucDAQHNeZmam3N3d1aRJk0vWVGT+/Pmy2+3mEBoaWm3bBQAAaperCkT/+te/NHDgwEvO79+/v8MNz9eqrKxMnTp10rx589SxY0eNHz9e48aN08qVKx3qbDabw7hhGOWm/dqVambMmKHc3FxzOHXqVNU3BAAA1GpXFYj+85//VPi4/UWurq766aefrrmpi4KDg9W2bVuHaW3atFF6erokKSgoSJLKnenJysoyzxoFBQWpuLhYOTk5l6ypiIeHh3x9fR0GAABQP11VILrhhhv05ZdfXnL+4cOHFRwcfM1NXfSb3/xGx48fd5j29ddf66abbpIkhYeHKygoSElJSeb84uJi7dixQ926dZMkRUdHy83NzaEmIyNDR44cMWsAAIC1XVUguuuuu/T888/r3Llz5eYVFhZq9uzZGjx4cLU198wzz2jPnj2aN2+eTpw4oY0bN2rVqlV64oknJF24VBYTE6N58+YpMTFRR44c0ejRo+Xt7a3hw4dLunBv09ixYzV58mRt27ZNBw8e1IgRI9SuXbtqfyoOAADUTVf12P1zzz2n9957T61atdKTTz6p1q1by2azKTU1Va+99ppKS0s1c+bMamvutttuU2JiombMmKG5c+cqPDxcS5cu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jDOOKQLRdfbOO+8oJiZGM2fO1MGDB9WjRw8NGjRI6enpFdanpaXprrvuUo8ePXTw4EH96U9/0lNPPaV33323hjuveVe7ry46fvy4MjIyzCEiIqKGOnaes2fPqn379lq+fHml6q18XF3tvrrIisfVjh079MQTT2jPnj1KSkrS+fPn1b9/f509e/aSy1j12KrKvrrIasfWjTfeqJdffln79+/X/v379dvf/lb33nuvjh49WmG9046pavl6Ki7p9ttvNx5//HGHaZGRkcb06dMrrJ86daoRGRnpMG38+PHGHXfccd16rC2udl9t377dkGTk5OTUQHe1lyQjMTHxsjVWPq7+W2X2FcfV/8nKyjIkGTt27LhkDcfWBZXZVxxb/6dJkybGm2++WeE8Zx1TnCG6joqLi5WSkqL+/fs7TO/fv792795d4TKff/55ufoBAwZo//79KikpuW69OltV9tVFHTt2VHBwsPr06aPt27dfzzbrLKseV9eC40rKzc2VJPn5+V2yhmPrgsrsq4usfGyVlpYqISFBZ8+eVdeuXSuscdYxRSC6jrKzs1VaWlruA7KBgYHlPjR7UWZmZoX158+fV3Z29nXr1dmqsq+Cg4O1atUqvfvuu3rvvffUunVr9enTRzt37qyJlusUqx5XVcFxdYFhGJo0aZK6d++uqKioS9ZxbFV+X1n52Pryyy/VqFEjeXh46PHHH1diYqLatm1bYa2zjinLfLrDmWw2m8O4YRjlpl2pvqLp9dHV7KvWrVurdevW5njXrl116tQpvfrqq7rzzjuva591kZWPq6vBcXXBk08+qcOHD2vXrl1XrLX6sVXZfWXlY6t169Y6dOiQTp8+rXfffVejRo3Sjh07LhmKnHFMcYboOgoICJCLi0u5MxxZWVnl0u9FQUFBFda7urrK39//uvXqbFXZVxW544479M0331R3e3WeVY+r6mK142rixInatGmTtm/frhtvvPGytVY/tq5mX1XEKseWu7u7WrZsqc6dO2v+/Plq3769li1bVmGts44pAtF15O7urujoaCUlJTlMT0pKUrdu3SpcpmvXruXqt2zZos6dO8vNze269epsVdlXFTl48KCCg4Oru706z6rHVXWxynFlGIaefPJJvffee/rkk08UHh5+xWWsemxVZV9VxCrH1q8ZhqGioqIK5zntmLqut2zDSEhIMNzc3IzVq1cbX331lRETE2M0bNjQOHnypGEYhjF9+nRj5MiRZv2///1vw9vb23jmmWeMr776yli9erXh5uZm/P3vf3fWJtSYq91XS5YsMRITE42vv/7aOHLkiDF9+nRDkvHuu+86axNqzJkzZ4yDBw8aBw8eNCQZixcvNg4ePGh89913hmFwXP23q91XVj6u/vjHPxp2u91ITk42MjIyzKGgoMCs4di6oCr7yqrH1owZM4ydO3caaWlpxuHDh40//elPRoMGDYwtW7YYhlF7jikCUQ147bXXjJtuuslwd3c3OnXq5PBY5qhRo4yePXs61CcnJxsdO3Y03N3djebNmxsrV66s4Y6d52r21YIFC4ybb77Z8PT0NJo0aWJ0797d+Mc//uGErmvexcd3fz2MGjXKMAyOq/92tfvKysdVRftJkrFmzRqzhmPrgqrsK6seW2PGjDH/u960aVOjT58+ZhgyjNpzTNkM43/vVAIAALAo7iECAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACUK/06tVLMTEx1/13bDab3n///ev+OwBqBoEIAC4jNjZWHTp0cHYbAK4zAhEAALA8AhGAOuvs2bN65JFH1KhRIwUHB2vRokUO84uLizV16lTdcMMNatiwobp06aLk5GRzfnx8vBo3bqz3339frVq1kqenp/r166dTp06Z8+fMmaN//etfstlsstlsio+PN5fPzs7W7373O3l7eysiIkKbNm2qic0GcB0QiADUWc8++6y2b9+uxMREbdmyRcnJyUpJSTHnP/roo/rss8+UkJCgw4cP6/7779fAgQP1zTffmDUFBQV66aWXtHbtWn322WfKy8vTgw8+KEl64IEHNHnyZN1yyy3KyMhQRkaGHnjgAXPZOXPmaNiwYTp8+LDuuusuPfzww/rll19qbgcAqD4GANRBZ86cMdzd3Y2EhARz2s8//2x4eXkZTz/9tHHixAnDZrMZP/zwg8Nyffr0MWbMmGEYhmGsWbPGkGTs2bPHnJ+ammpIMvbu3WsYhmHMnj3baN++fbnfl2Q899xz5nh+fr5hs9mMjz76qDo3E0ANcXVyHgOAKvn2229VXFysrl27mtP8/PzUunVrSdKBAwdkGIZatWrlsFxRUZH8/f3NcVdXV3Xu3Nkcj4yMVOPGjZWamqrbb7/9sj3ceuut5r8bNmwoHx8fZWVlXdN2AXAOAhGAOskwjMvOLysrk4uLi1JSUuTi4uIwr1GjRg7jNput3PIVTfs1Nze3csuUlZVdcTkAtQ/3EAGok1q2bCk3Nzft2bPHnJaTk6Ovv/5aktSxY0eVlpYqKytLLVu2dBiCgoLMZc6fP6/9+/eb48ePH9fp06cVGRkpSXJ3d1dpaWkNbRUAZyEQAaiTGjVqpLFjx+rZZ5/Vtm3bdOTIEY0ePVoNGlz4z1qrVq308MMP65FHHtF7772ntLQ07du3TwsWLNA///lPcz1ubm6aOHGi9u7dqwMHDujRRx/VHXfcYV4ua968udLS0nTo0CFlZ2erqKjIKdsL4PoiEAGos1555RXdeeedGjJkiPr27avu3bsrOjranL9mzRo98sgjmjx5slq3bq0hQ4Zo7969Cg0NNWu8vb01bdo0DR8+XF27dpWXl5cSEhLM+b///e81cOBA9e7dW02bNtXbb79do9sIoGbYjCtdiAeAeio+Pl4xMTE6ffq0s1sB4GScIQIAAJZHIAIAAJbHJTMAAGB5nCECAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACWRyACAACW9/8B3lGu4kR98TAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plot_depth_dist(train_df)\n",
    "plot_depth_dist(val_df)\n",
    "plot_depth_dist(test_df)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sftcontext",
   "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
