{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "MR78W33XK6_9"
   },
   "source": [
    "The goal of this notebook is to automatically generate and solve Laplace integral problems to create a training set for a LLM."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "W6SwUsIwbPIo"
   },
   "source": [
    "# Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 654,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 24139,
     "status": "ok",
     "timestamp": 1706814551955,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "zcVuk209kcjt",
    "outputId": "33e50e16-e16c-4d39-dc9a-3971bd3ddef9"
   },
   "outputs": [],
   "source": [
    "import sympy as sp\n",
    "from sympy import diff, solve, N, limit, latex\n",
    "import numpy as np\n",
    "import random\n",
    "from IPython.display import display, Math\n",
    "from scipy.optimize import dual_annealing\n",
    "from scipy.integrate import quad\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import os\n",
    "\n",
    "# from google.colab import drive\n",
    "\n",
    "# drive.mount(\"/content/gdrive\", force_remount=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "VkhDzEcYiQsL"
   },
   "source": [
    "# Functions to generate laplace integrals"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "xewu6xjRoCpA"
   },
   "source": [
    "Here are the functions that we use to generate random Laplace integrals. The rest of the methods are fairly robust, so if we would like to train the LLM on a more general class of Laplace integrals later, we can simply alter these functions. The only constraint is that we cannot generate f(t) or g(t) that diverge within the bounds of the integral."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 655,
   "metadata": {
    "executionInfo": {
     "elapsed": 4,
     "status": "ok",
     "timestamp": 1706814551955,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "I6KUfCiSK4u1"
   },
   "outputs": [],
   "source": [
    "### Generate random functions ###\n",
    "\n",
    "def generate_linear_combination(max_num_terms):\n",
    "\n",
    "  \"\"\"\n",
    "  This function generates a random linear combination of the sympy functions\n",
    "  specified in the dictionary.\n",
    "  \"\"\"\n",
    "\n",
    "  # Define the variable\n",
    "  t = sp.symbols('t')\n",
    "\n",
    "  # Define list of functions\n",
    "  functions = np.array([\n",
    "      1,\n",
    "      sp.sin(t),\n",
    "      sp.cos(t),\n",
    "      sp.atan(t),\n",
    "      #sp.sinc(t),\n",
    "      t,\n",
    "      t**2,\n",
    "      t**3,\n",
    "      t**4,\n",
    "      t**5\n",
    "      ])\n",
    "\n",
    "  # Generate a random number of terms\n",
    "  num_terms = random.randint(1, max_num_terms)\n",
    "\n",
    "  # Generate random coefficients\n",
    "  possible_coeffs = np.arange(-3, 3, 0.1)\n",
    "  coefficients = np.round(np.random.choice(possible_coeffs, num_terms), 1)\n",
    "\n",
    "  # Draw random indices\n",
    "  indices = random.choices(range(len(functions)), k=num_terms)\n",
    "\n",
    "  # If our function will just be a constant, redraw the index\n",
    "  if len(indices) == 1 and indices[0] == 0:\n",
    "    indices = random.choices(range(1, len(functions)), k=1)\n",
    "\n",
    "  # Get linear conbinations of these functions\n",
    "  f = sum(coefficients * functions[indices])\n",
    "\n",
    "  return f"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 656,
   "metadata": {
    "executionInfo": {
     "elapsed": 2,
     "status": "ok",
     "timestamp": 1706814551955,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "M2Rp5264poUn"
   },
   "outputs": [],
   "source": [
    "### Define a function to generate the bounds of the integral ###\n",
    "def generate_bounds(range):\n",
    "\n",
    "  \"\"\"\n",
    "  This function generates bounds within a given range.\n",
    "\n",
    "  range: [lower, upper]\n",
    "  \"\"\"\n",
    "\n",
    "  # Get possible bounds on range\n",
    "  possible_bounds = np.arange(range[0], range[1], 0.1)\n",
    "\n",
    "  # Draw bounds\n",
    "  bounds = np.random.choice(possible_bounds, 2, replace=False)\n",
    "\n",
    "  # Get lower, upper bound\n",
    "  lower = np.min(bounds)\n",
    "  upper = np.max(bounds)\n",
    "\n",
    "  return np.round(lower, 1), np.round(upper, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 657,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1706814552434,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "qUavc1XXoqUo"
   },
   "outputs": [],
   "source": [
    "### Generate Laplace integral ###\n",
    "\n",
    "def generate_integral(function_generator, bounds_generator, max_num_terms, range):\n",
    "\n",
    "  \"\"\"\n",
    "  This function generates all the components of a Laplace integral given\n",
    "  the various generator functions.\n",
    "\n",
    "  It returns ((lower, upper), g(t), f(t), sign) where the integral\n",
    "  is given by \\int_{lower}^{upper} g(t) e^{sign * x * f(t)} dt\n",
    "\n",
    "  function_generator: function that generates f, g\n",
    "  bounds_generator: function that generates bounds\n",
    "  max_num_terms: most terms the function could have\n",
    "  range: range within which bounds fall\n",
    "  \"\"\"\n",
    "\n",
    "  # Generate f(t), g(t)\n",
    "  f = function_generator(max_num_terms)\n",
    "  g = function_generator(max_num_terms)\n",
    "\n",
    "  # Generate bounds\n",
    "  bounds = bounds_generator(range)\n",
    "\n",
    "  # Generate sign\n",
    "  sign = -1 if random.random() < 0.5 else 1\n",
    "\n",
    "  return bounds, g, f, sign"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "129KnpFdulQJ"
   },
   "source": [
    "# Functions to find the minimum of f(t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "l_1fZitgE-xs"
   },
   "source": [
    "Here, we define functions to find the minimum of f(t) within specified bounds.We first attempt to find it analytically using SymPy. If this fails, we use 5 iterations of dual annealing to find it numerically. This should be fairly robust, even in the face of rapidly oscillating functions with multiple minima. However, if there are functions that have >5 minima within the bounds, this will of course not find them all. So, if we make the integral generation significantly more complex in the future, we may have to edit this slightly."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 658,
   "metadata": {
    "executionInfo": {
     "elapsed": 245,
     "status": "ok",
     "timestamp": 1706814552677,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "eGwXL-eJ3yDo"
   },
   "outputs": [],
   "source": [
    "### Define a function to determine whether we can find the global minima of f analytically ###\n",
    "\n",
    "def analytical_critical_pts(f, lower, upper):\n",
    "\n",
    "  \"\"\"\n",
    "  This function determines whether we can find the global minima of f within\n",
    "  the specified bounds analytically using sympy.\n",
    "\n",
    "  If solveset returns an empty set or only a finite set, then sympy was able\n",
    "  to solve for the critical points analytically. If it returns anything else,\n",
    "  sympy was not able to find all critical points analytically.\n",
    "\n",
    "  This returns a list of all the critical points the critical points if sympy\n",
    "  could all of them analytically. To distinguish between an empty list that\n",
    "  implies no critical points and one that implies no analytical solution, we also\n",
    "  return a 0 if sympy could not find analytical solutions and a 1 if it could.\n",
    "  \"\"\"\n",
    "\n",
    "  # Define symbol for t\n",
    "  t = sp.symbols('t')\n",
    "\n",
    "  # Define bounds in sympy\n",
    "  domain = sp.Interval(lower, upper)\n",
    "\n",
    "  # Get local minima\n",
    "  solutions = sp.solveset(diff(f, t), t, domain=domain)\n",
    "\n",
    "  # Check if the solutions are the empty set\n",
    "  if solutions == sp.EmptySet:\n",
    "   return [], 1\n",
    "\n",
    "  # Check if the solutions a finite set\n",
    "  elif isinstance(solutions, sp.FiniteSet):\n",
    "    return list(solutions), 1\n",
    "\n",
    "  # If it's anything else, solveset got no analytical insights\n",
    "  else:\n",
    "    return [], 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 659,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1706814552677,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "EfgOhFBfzT2r"
   },
   "outputs": [],
   "source": [
    "## Define function to find minima numerically using many iterations of dual annealing\n",
    "def find_minima_numerically(f, lower, upper, num_start_pts=5):\n",
    "\n",
    "  \"\"\"\n",
    "  This function uses the dual annealing algorithm to find the minima of f on\n",
    "  the specified bounds.\n",
    "\n",
    "  f: sympy expression for the function to minimize\n",
    "  lower: lower bound, float\n",
    "  upper: upper bound, float\n",
    "  num_start_pts: the number of times to run the dual annealing algorithm. default=5\n",
    "  \"\"\"\n",
    "\n",
    "  # Format bounds for dual annealing\n",
    "  bounds = [(lower, upper)]\n",
    "\n",
    "  # Define list of starting points to increase the chance of finding all global minima\n",
    "  start_pts = np.linspace(lower, upper, num_start_pts)\n",
    "\n",
    "  # Define list to store global minima\n",
    "  min_points = []\n",
    "\n",
    "  # Run dual annealing from each starting point to increase chance of finding all global minima\n",
    "  for start in start_pts:\n",
    "      result = dual_annealing(lambda x: float(N(f.subs('t', x[0]))), bounds, x0=[start])\n",
    "      min_points.append(round(result.x[0],4))  # round to 4 decimal pts bc algorithm results vary slightly\n",
    "\n",
    "  # Take only unique minima\n",
    "  min_points = list(set(min_points))\n",
    "\n",
    "  return min_points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 660,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1706814552677,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "xBwSTB-MyX-Q"
   },
   "outputs": [],
   "source": [
    "### Define function to find the global minima of f within the bounds, analytically or numerically ###\n",
    "def find_global_min(f, bounds):\n",
    "\n",
    "  \"\"\"\n",
    "  This function finds the global minima of f within the bounds. It also records\n",
    "  whether or not the global minima were found analytically for future response\n",
    "  generation purposes. It also returns the critical points, if we could find\n",
    "  them analytically, for the same purpose.\n",
    "  \"\"\"\n",
    "\n",
    "  # Define symbol\n",
    "  t = sp.symbols('t')\n",
    "\n",
    "  # Extract bounds\n",
    "  lower, upper = bounds\n",
    "\n",
    "  ## Attempt to find critical points analytically\n",
    "  critical_points, complete = analytical_critical_pts(f, lower, upper)\n",
    "\n",
    "\n",
    "  ## If this is a complete list of critical points, find the global minimum\n",
    "  if complete:\n",
    "\n",
    "    # Record that we could find minimum analytically\n",
    "    analytic_min = True\n",
    "\n",
    "    # Evaluate the function at the critical points and the endpoints\n",
    "    critical_values = [(N(f.subs(t, point)), point) for point in critical_points if lower <= point <= upper]\n",
    "    endpoint_values = [(N(f.subs(t, lower)), lower), (N(f.subs(t, upper)), upper)]\n",
    "\n",
    "    # Combine the lists and find the minimum value(s)\n",
    "    values = critical_values + endpoint_values\n",
    "    min_value = min(v[0] for v in values)\n",
    "    min_points = [v[1] for v in values if v[0] == min_value]\n",
    "\n",
    "    return min_points, analytic_min, critical_points\n",
    "\n",
    "\n",
    "  ## If it is not a complete list, look for the global minimum numerically\n",
    "  else:\n",
    "\n",
    "    # Record that we could not find minimum analytically\n",
    "    analytic_min = False\n",
    "\n",
    "    # Get minima numerically with dual annealing\n",
    "    min_points = find_minima_numerically(f, lower, upper, num_start_pts=5)\n",
    "\n",
    "    return min_points, analytic_min, None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "twpudsSLk2LD"
   },
   "source": [
    "# Functions to analytically approximate laplace integrals"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "_zQyDwK4apg0"
   },
   "source": [
    "Here we define functions to return the approximation for the laplace integral by using the formulae derived in class. They also return any imformation needed for prompt generation."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 661,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1706814552677,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "82m_cIXmypMK"
   },
   "outputs": [],
   "source": [
    "### Define function to approximate laplace integral if f(t) has a single minimum ###\n",
    "def single_min_laplace_integral(bounds, g, f, sign, minimum):\n",
    "\n",
    "  \"\"\"\n",
    "  This function returns the analytical formula for the approximation of a laplace\n",
    "  integral given the single minimum of f(t). This will be used in the final\n",
    "  laplace integral function in the case that f(t) has one minimum within the\n",
    "  bounds. It also returns whether or not the minimum/maximum\n",
    "  of f(t) was on the bounds of the integral, and if it is, which bound,\n",
    "  as we will use this in our response generation.\n",
    "  \"\"\"\n",
    "\n",
    "  # Define symbols\n",
    "  t, x = sp.symbols(\"t x\")\n",
    "\n",
    "  # Deal with sympy zero class, which is not compatible with numpy\n",
    "  if minimum == sp.S.Zero:\n",
    "    minimum = 0.0\n",
    "\n",
    "  # Get f(min), g(min). Use limits to avoid division by 0 issues\n",
    "  f_t0 = limit(f, t, minimum)\n",
    "  g_t0 = limit(g, t, minimum)\n",
    "\n",
    "  # If the minimum is on a bound\n",
    "  if minimum in np.round(bounds, 4):  # must round bounds to 4 decimal places bc minimum is rounded too\n",
    "\n",
    "    # Get f'(min)\n",
    "    fp_t0 = limit(diff(f,t), t, minimum)\n",
    "\n",
    "    # Record the min/max is on bounds\n",
    "    minmax_on_bounds = True\n",
    "\n",
    "    # Record which bound it is\n",
    "    if minimum == np.round(bounds, 5)[0]:\n",
    "      which_bound = \"a\"\n",
    "    else:\n",
    "      which_bound = \"b\"\n",
    "\n",
    "    # Approximation when minimum is on the bound\n",
    "    return g_t0 * sp.exp(sign * x * f_t0) / (sp.Abs(fp_t0) * x), minmax_on_bounds, which_bound\n",
    "\n",
    "  # Minimum is within bounds\n",
    "  else:\n",
    "\n",
    "    # Record the min/max is not on bounds\n",
    "    minmax_on_bounds = False\n",
    "\n",
    "    # Get f''(min)\n",
    "    fpp_t0 = limit(diff(f,t,2), t, minimum)  # take the limit in case L'Hopital needed\n",
    "\n",
    "    # Approximation when minimum is within interval\n",
    "    return sp.sqrt(sp.pi) * g_t0 * sp.exp(sign * x * f_t0) * sp.sqrt(2 / (sp.Abs(fpp_t0) * x)), minmax_on_bounds, None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 662,
   "metadata": {
    "executionInfo": {
     "elapsed": 192,
     "status": "ok",
     "timestamp": 1706814552867,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "ZcStIVPyk_cX"
   },
   "outputs": [],
   "source": [
    "### Define function to analytically approximate laplace integrals ###\n",
    "\n",
    "def approximate_laplace_integral(bounds, g, f, sign):\n",
    "\n",
    "  \"\"\"\n",
    "  This function returns an analytical approximation for the Laplace\n",
    "  integral defined by \\int_{lower}^{upper} g(t) e^{sign * x * f(t)} dt\n",
    "  in the limit of large x. It also returns whether or not the minimum/maximum\n",
    "  of f(t) was on the bounds of the integral, and how many minima/maxima there\n",
    "  were, and whether or not they were found analytically, the global min/maxima,\n",
    "  and the critical points (if it was found analytically), and which bound the\n",
    "  min/max is on, if it is on a bound. We will use this in our response generation\n",
    "  later.\n",
    "  \"\"\"\n",
    "\n",
    "  # Define symbols\n",
    "  t, x = sp.symbols(\"t x\")\n",
    "\n",
    "  # If the sign is positive, multiple f by -1 so minimization maximizes f\n",
    "  if sign == 1:\n",
    "    f = -1 * f\n",
    "\n",
    "  # Find the global minimum of f within the bounds\n",
    "  minima, analytic_min, critical_points = find_global_min(f, bounds)\n",
    "\n",
    "  # If sign is positive, multiply f by -1 to return it to normal\n",
    "  if sign == 1:\n",
    "    f = -1 * f\n",
    "\n",
    "  # Check for edge case where find_global_min function does not return any values\n",
    "  if len(minima) == 0:\n",
    "    return ValueError(\"Minima function returned no values\")\n",
    "\n",
    "  # If there is only one minimum\n",
    "  elif len(minima) == 1:\n",
    "\n",
    "    # Get analytical approximation using the single min laplace integral approximation\n",
    "    approximation, minmax_on_bounds, which_bound = single_min_laplace_integral(bounds, g, f, sign, minima[0])\n",
    "\n",
    "    # Record number of min/max\n",
    "    num_minmax = 1\n",
    "\n",
    "    return approximation, minmax_on_bounds, num_minmax, analytic_min, minima, critical_points, which_bound\n",
    "\n",
    "  # If there is more than minimum, imagine breaking the integration interval in pieces. Apply single minimum approximation to each\n",
    "  else:\n",
    "\n",
    "    # Record number of min/max\n",
    "    num_minmax = len(minima)\n",
    "\n",
    "    # Initialize variable to hold final approximation\n",
    "    approximation = 0\n",
    "\n",
    "    # Loop through each set of bounds, adding contribution to integral from single minimum formula\n",
    "    for i in range(num_minmax):\n",
    "\n",
    "      # Add approx from single minimum approximation formula\n",
    "      approximation += single_min_laplace_integral(bounds, g, f, sign, minima[i])[0]\n",
    "\n",
    "    # Record that min/max likely not on bounds (true except in very extreme case)\n",
    "    minmax_on_bounds = False\n",
    "\n",
    "  return approximation, minmax_on_bounds, num_minmax, analytic_min, minima, critical_points, None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "irKWcU1y-atO"
   },
   "source": [
    "# Functions to compare approximation to numerical solution"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "swyn5wmdckbP"
   },
   "source": [
    "Here we define function to compare the analytical approximation to the numerical solution."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 663,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Define function to evaluate the analytical approximation at given x values\n",
    "def evaluate_analytical(analytical_approximation, xs, max_val=np.inf):\n",
    "\n",
    "  \"\"\"\n",
    "  This function evaluates the analytical approximation for each x\n",
    "  value in the array xs. It returns an array containing the results.\n",
    "\n",
    "  Specify a maximum value allowed in the array to avoid the matplotlib\n",
    "  plotting issues that arise for values above 10^100.\n",
    "\n",
    "  analytical_approximation: sympy expression for your approximation\n",
    "  xs: array of x values at which we evaluate the approximation\n",
    "  max_val: maximum value allowed in the return array\n",
    "  \"\"\"\n",
    "\n",
    "  approx_vals = np.array([analytical_approximation.subs(x, x_val).evalf() \\\n",
    "                for x_val in xs \\\n",
    "                if np.abs(analytical_approximation.subs(x, x_val).evalf()) < max_val])\n",
    "\n",
    "  return approx_vals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 664,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Perform numerical integration of laplace integral for set of x values\n",
    "def integrate_numerically(bounds, g, f, sign, xs, max_error):\n",
    "\n",
    "  \"\"\"\n",
    "  This function finds the solution to the Laplace integral defined by f, g, sign,\n",
    "  and bounds for each x in the array xs. It truncates any computation if the\n",
    "  integration error exceeds max_error. It returns an array of the numerical results.\n",
    "\n",
    "  bounds: tuple (a, b), bounds of the laplace integral\n",
    "  g: sympy expression for g(t)\n",
    "  f: sympy expression for f(t)\n",
    "  xs: array of x values at which we evaluate the integral\n",
    "  max_error: the maximum integration error allowed before we stop computation\n",
    "  \"\"\"\n",
    "\n",
    "  # Define the function you want to integrate\n",
    "  integrand = g * sp.exp(sign*x*f)\n",
    "\n",
    "  # Define the function you want to integrate\n",
    "  def evaluate_integrand(x_val, t_val):\n",
    "      return integrand.subs(x,x_val).subs(t,t_val).evalf()\n",
    "\n",
    "  # Define bounds over which we want to integrate\n",
    "  lower, upper = bounds\n",
    "\n",
    "  # Initialize array to store integration data\n",
    "  # numerical_vals = np.zeros(len(xs))\n",
    "  # numerical_vals[:] = np.nan\n",
    "\n",
    "  numerical_vals = []\n",
    "\n",
    "  # Calculate integral for each lambda\n",
    "  for idx, x_val in enumerate(xs):\n",
    "\n",
    "    # Perform integration\n",
    "    integral, error = quad(lambda t: evaluate_integrand(x_val, t), lower, upper)\n",
    "\n",
    "    # Save data\n",
    "    numerical_vals.append(integral)\n",
    "\n",
    "    # Stop if quad breaks\n",
    "    if error > max_error:\n",
    "      break\n",
    "\n",
    "  return numerical_vals, len(numerical_vals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 665,
   "metadata": {
    "executionInfo": {
     "elapsed": 176,
     "status": "ok",
     "timestamp": 1706814553722,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "voV4JpEQTdPw"
   },
   "outputs": [],
   "source": [
    "# Plot results\n",
    "def plot_results(approx_vals, numerical_vals, xs):\n",
    "\n",
    "  \"\"\"\n",
    "  This function plots the numerical solution and the analytical approximation\n",
    "  given an array of values for each.\n",
    "\n",
    "  approx_vals: array of values given by the analytical approximation\n",
    "  numerical_vals: array of values given by the numerical integration\n",
    "  xs: array of x values at which we computed the integral\n",
    "  \"\"\"\n",
    "\n",
    "  # Get length of numerical_vals array\n",
    "  len_num_vals = len(numerical_vals)\n",
    "  len_approx_vals = len(approx_vals)\n",
    "\n",
    "  # Set up plotting\n",
    "  plt.figure(figsize=(10,6))\n",
    "  plt.rcParams.update({'font.size': 22})\n",
    "\n",
    "  # Plot approximation and numerical solution\n",
    "  plt.loglog(xs[:len_approx_vals], np.abs(approx_vals), \\\n",
    "             linewidth=4, label=\"approximation\")\n",
    "  plt.loglog(xs[:len_num_vals], np.abs(numerical_vals), \\\n",
    "             'o', mfc='none', markersize=8, label='numerical')\n",
    "\n",
    "  # Set up legend, title, x label\n",
    "  plt.legend(bbox_to_anchor=(1.05, 1), loc=2, borderaxespad=0.)\n",
    "  plt.title(\"Testing result\")\n",
    "  plt.xlabel(\"x\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "cnxkYqjF_cAX"
   },
   "source": [
    "# Testing Results"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "i8RS8TCnizCy"
   },
   "source": [
    "This section of the notebook allows us to quickly test our results. We quantitatively test our approximation accuracy in the next section."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 670,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 203
    },
    "executionInfo": {
     "elapsed": 311,
     "status": "ok",
     "timestamp": 1706814556946,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "dhODLBpUJBjX",
    "outputId": "eea3ec71-9ce9-4263-a9ec-993350791825"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generated Integral \n",
      "\n"
     ]
    },
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\int\\limits_{-0.8}^{-0.1} \\left(0.4 t - 3.0 \\cos{\\left(t \\right)}\\right) e^{x \\left(- 0.3 t^{3} + 1.2 \\operatorname{atan}{\\left(t \\right)}\\right)}\\, dt$"
      ],
      "text/plain": [
       "<IPython.core.display.Math object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      " Approximation \n",
      "\n"
     ]
    },
    {
     "data": {
      "text/latex": [
       "$\\displaystyle - \\frac{2.56548573846253 e^{- 0.119302382989394 x}}{x}$"
      ],
      "text/plain": [
       "-2.56548573846253*exp(-0.119302382989394*x)/x"
      ]
     },
     "execution_count": 670,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Define symbols\n",
    "x, t = sp.symbols('x t')\n",
    "\n",
    "# Generate integral\n",
    "bounds, g, f, sign = generate_integral(generate_linear_combination, generate_bounds, max_num_terms=5, range=[-1,1])\n",
    "\n",
    "# Print integral\n",
    "print(\"Generated Integral \\n\")\n",
    "integral = sp.Integral(g * sp.exp(sign*x*f), (t, bounds[0], bounds[1]))\n",
    "latex_integral = sp.latex(integral)\n",
    "display(Math(latex_integral))\n",
    "\n",
    "# Generate approximation\n",
    "approximation = approximate_laplace_integral(bounds, g, f, sign)[0]\n",
    "\n",
    "# Print approximation\n",
    "print(\"\\n Approximation \\n\")\n",
    "approximation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 671,
   "metadata": {
    "executionInfo": {
     "elapsed": 6685,
     "status": "ok",
     "timestamp": 1706814565516,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "A49G04h8WWVE"
   },
   "outputs": [],
   "source": [
    "## Compare analytical approximation and numerical solution\n",
    "\n",
    "# Define array of xs to test on\n",
    "xs = np.logspace(-1, 3, 300)\n",
    "\n",
    "# Get numerical solution\n",
    "numerical_vals, num_vals = integrate_numerically(bounds, g, f, sign, xs, max_error=1000)\n",
    "\n",
    "# Get analytical approximation\n",
    "approx_vals = evaluate_analytical(approximation, xs, max_val=10**100)[:num_vals]\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 672,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 607
    },
    "executionInfo": {
     "elapsed": 1980,
     "status": "ok",
     "timestamp": 1706814568375,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "2uM68Oj7TYyN",
    "outputId": "17695d96-a283-4fc0-edb9-b26254d29f1e"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABOsAAAJTCAYAAABZ1ZJmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAADi1UlEQVR4nOzdd3hUZdrH8e+Zll5JQoBQAkiVIgiiqCBYwIaKiqIitkVR13X1VXF3rbuWtfeGvSCrIFhQBAQLSpfeIXQSSO/JlPP+cciQIZ2SBPh9ritXZuZ5zjnPTMbg3Lnv5zZM0zQRERERERERERGRBmdr6AWIiIiIiIiIiIiIRcE6ERERERERERGRRkLBOhERERERERERkUZCwToREREREREREZFGQsE6ERERERERERGRRkLBOhERERERERERkUZCwToREREREREREZFGQsE6ERERERERERGRRkLBOhERERERERERkUZCwToRETluPPLIIxiGgWEYDBw4sKGXI0e5sveSYRjMmTOnoZcjIiIiIscIR0MvQEREDs2WLVtITk4+Iud++OGHeeSRR47IuQ/Fiy++SHZ2NgCXXHIJPXv2bND1iFRH71cRERERqQsF60RE5Kjz4osvsnXrVgDatGmj4Ic0anq/ioiIiEhdKFgnInKUczqdtGvXrsZ5e/bsIS8vz3+/NsfExsYe0tpERERERESkbhSsExE5yrVo0YKNGzfWOG/06NF8+OGH/vu1OeZY88gjjzTKsl4REREREZEyajAhIiIiIiIiIiLSSCizTkREquXz+ViwYAHr1q0jLS0Np9NJs2bNOOOMM2jRosVBnXPt2rUsWbKEtLQ0CgoKCA4OJiYmhuTkZHr27Nmoy2/dbjdz5sxh8+bNZGVlERcXR9++fenevftBn3PJkiUsXbqUPXv20KRJE5KTkxkwYABOp/MwrrxuvF4vc+fOZfPmzaSmphISEsKwYcNo06ZNlcfk5OTw66+/snPnTjIzM/0/0wEDBhAcHFznNRQXF7N48WJWrVpFVlYWHo+HsLAwmjVrRvv27enevXuDvkYiIiIiIkeEKSIix4Xrr7/eBPxfNcnNzTXHjRtnxsfHBxxX9mUYhnnmmWeaixYtqvUaPvnkE7NLly6Vnq/8ebt162a++uqrAce+//771R5X2VdKSkrAOR5++GH/2IABA6pcZ/l5rVu3Nk3TNH0+n/n000+bCQkJlV6rZ8+e5h9//FHr18I0TfPHH380O3XqVOn5mjZtaj799NOmz+czTdMMGJs9e3adrlOVA19T0zRNr9drPvXUU2ZiYmKFNb3//vuVnmfZsmXmBRdcYDqdzkqfS1hYmHnXXXeZ2dnZtVpXdna2edddd5lRUVHV/nxDQkLMCy64wFyyZEml5yn/nr/++utrde2UlJRq30PlVfczORzvVxERERE5PqkMVkREKliyZAkdO3bkySefZO/evZXOMU2TX375hb59+/Lmm29Wez7TNLnlllu49tprWb16dY1zV6xYwfvvv3/Q6z/cSkpKuPDCC7n//vvZs2dPpXOWLl3KoEGDmD17dq3O+dRTT3Huueeydu3aSsfT0tK4//77ufTSS/F4PAe99rooLS1lyJAhPPDAA6SmptbqmP/85z+cdNJJfPfdd7jd7krnFBQU8NJLL9G9e/ca90rctm0bJ510Ei+99BI5OTnVzi0qKuK7775j7ty5tVqriIiIiMjRQGWwIiISYMGCBZx99tkBnWNPPPFELrzwQpKTk/F6vSxfvpyJEyeSlZWFz+fjtttuIzIykpEjR1Z6zjfffJPx48f770dHRzNs2DC6d+9ObGwspaWlpKens2LFCmbPnk1aWlqFc0RGRvo72G7dutUfwEpISCAiIqLS6x6uEsmxY8cybdo0AM4++2wGDx5MQkICGRkZfP311/z222+AFTy67rrrWLNmTZVrAvjwww8ZN26c/75hGJx99tmcc845xMbGsnv3br755hsWLFjA1KlTefTRRw/L86jJ3//+d2bMmAFA3759Of/880lKSiInJ4cFCxbgcrkC5j/wwAM8/fTT/vsOh4OhQ4dy+umnExcXR2ZmJjNnzmT69OmAFYgbOHAgS5cuJS4ursL1TdNkxIgRpKSk+B/r2rUr559/Pm3btiUkJIS8vDy2b9/O4sWL+fXXXyktLT0SL8Uha8j3q4iIiIgc5Ro2sU9EROpLbcpgc3NzzbZt2waUGX700Uf+Uszy9uzZYw4cONA/NyYmxty1a1el523durV/3hlnnGFmZWVVuU6v12vOmjXLvO+++6qcU/58VZVmVuZgymANwzABMz4+3vz1118rnf/0008HvLYvvvhiledOTU01o6Oj/XMjIiLMGTNmVDr33XffNe12u2mz2eqlDBYwg4KCzM8//7zGY7/99tuA40466SRz3bp1lc6dOXOmGRkZ6Z87YsSISuf99NNPAed87rnnql1DTk6O+corr5iTJk2qdLwhy2DLO9j3q4iIiIgcn1QGKyIifk888QSbN28GwGazMWnSJK677joMw6gwNz4+nm+//Zb27dsDkJWVxfPPP19h3ubNm9m6dav//muvvUZ0dHSVa7DZbAwaNCggY6shmaaJ0+nkhx9+4PTTT690zn333ceAAQP89ydMmFDl+Z5//nmys7P99z/77DPOPvvsSufeeOONPPXUU/h8voNb/EF45513GDFiRLVzPB4Pt912m/9+x44dmTNnDh06dKh0/uDBg/niiy/89ydOnMiqVasqzCtfQtyrVy/+/ve/V7uOyMhI7rjjDi677LJq54mIiIiIHE0UrBMREcAq4Xz77bf996+//nqGDh1a7TFhYWEBQbUPPvigwr5lB+59VhbcO5r85S9/oVevXtXOufnmm/23ly5dWuk+c16vl48++sh//9xzz+XCCy+s9rx/+9vfaNu2bR1XfHD69OnDddddV+O8SZMmsX37dv/9t956i8jIyGqPOffcc7nooov898u/18qUf68cje8TEREREZHDQcE6EREB4McffyQzM9N//6677qrVccOGDfMHatLT01m2bFnAeGhoaMD9efPmHeJK69+oUaNqnHPKKaf4b5eUlLBly5YKc5YvXx4QkBo9enSN53U4HFxzzTW1Wuehqk2gDuDzzz/33+7Zs2dAVmFtzz9r1qwK4+XfK4sXL66yYYWIiIiIyLFMwToREQEI6KiZmJhIjx49anWc3W4PyDpbuHBhwHinTp0IDg7237/++uv56aefDnG19cfpdHLSSSfVOK958+YB98uXupZZvHhxwP0zzzyzVmuo7bxDdeqpp9Zq3u+//+6/PWTIkFqfv2/fvv7ba9asIT8/P2C8/Ou8adMmrrnmGnbt2lXr84uIiIiIHAsUrBMREYCAjLjOnTvX6dimTZv6b+/YsSNgLDg4OCAzbfv27QwePJhOnTpx//33M3369IDOs41NbGxsrbp0hoWFBdwvKCioMKd8l9OIiAhatGhRqzXU9edxsMq6l1Zn9+7d7Nmzx3+/Lmsr/z7x+Xzs3r07YHz48OE0adLEf/+LL76gdevWDBkyhBdffJGlS5fW6/59IiIiIiINQcE6EREBICMjw3979uzZGIZR66+JEyf6j60so+yZZ56hd+/eAY+tW7eO//73vwwZMoTY2Fj69+/PM888Q1pa2hF7jgejfFZgXZimWeGxnJwc/+2YmJhan6u6hhyHU0RERI1zyr9PwMqUrO37JCQkJODYA98r4eHhTJgwIaAc1uPxMH36dO6++25OOukk4uLiuPLKK/nqq68q3RdQRERERORop2CdiIgAgYGkQ1FYWFjhscjISH799Vf+9a9/VRqk8ng8/P7779x3330kJyfz8MMP4/V6D8t6GpOSkhL/bZfLVevjgoKCjsRyKnA4HDXOOVzvE6j8vXLOOeewaNEiLrroImy2iv+bkpWVxRdffMFll11G165dAzrIioiIiIgcC2r+v3IRETkulM9mioqKIi4u7qDOk5CQUOnjISEhPPbYYzz44IP8+OOPzJw5k19//ZXly5cHlDYWFRXx2GOPsXbt2oCMvWNB+Y6pB+7XVp3GVCZ8YMOQpKSkgw4mVpW12LlzZ77++mu2b9/Od999x+zZs/n1118rlM2uX7+ec845h8mTJ3PxxRcf1BpERERERBobBetERAQgYK+wCy64gE8//fSIXCc4OJiLL77YH1zJyspi+vTpfPLJJ0ybNs1fPvq///2Pq6++mksuueSIrKMhlA+A7t27l+Li4lqV2R64D2BDKv8+AXjvvfc455xzjsi1WrZsya233sqtt94KWE0ppk6dyvjx49m0aRMAXq+XMWPGcO6551Z4LQ3DqPM1i4qKDn3hIiIiIiKHQGWwIiICQMeOHf23165dW2/XjYmJ4aqrruLbb79l6tSpAaWPEyZMqLd11Idu3br5b3u9XlasWFGr4/78888jtaQ6a968OeHh4f779fle6dy5Mw888ABr1qxh5MiR/sdTU1MrLYctnwVYWcltZRrbnokiIiIicvxRsE5ERAAYMGCA//aff/5ZoeSwPlx00UUB5Yxr1qypdF757qxHU3fQvn37BmR7TZ06tVbHTZky5QitqO4cDgf9+/f33582bVq9r8HpdPLaa68FvJaVvVfKN+bYtWtXrc49b968Q17fgY7W96uIiIiINAwF60REBIAhQ4b4u4Gapslzzz3XIOvo0KGD/3ZV3T7LZ3YdzoYHR1pCQgKDBg3y33/rrbcq7Z5b3po1a/jmm2+O8Mrq5oorrvDfnj59OsuXL6/3NURHRxMfH++/X9l7pfx7aenSpRQXF1d7TtM0+fDDDw/fIvc5Wt+vIiIiItIwFKwTERHACn6MGTPGf/+ll15ixowZdTpHZcGQ1NRUSktLa32O8qWhrVu3rnRO+cdXrlxZhxU2vDvuuMN/Oz09nZtuuqnKbKv8/Hyuu+66KoOWDeW6666jRYsWgBXguvbaa+vcBKOy98rWrVtrffzu3bvJyMjw36/svXLKKaf4bxcUFNTYsOT5558/ImW9R/P7VURERETqn4J1IiLi989//pN27doBVqbSRRddxMsvv1xjsG358uXce++9AcGRMj/88APJyck8/fTTNTZKeO211/j+++/996vq8Fn+OhMnTqx0v7LG6pJLLuG8887z3588eTKDBg3ijz/+8D/m9Xr5/vvv6du3L4sXL6Zz584NsdQquVwu3njjDX8Z6ooVK+jXrx8LFiyo9rji4mK+/vprhgwZwtNPP11hfPTo0QwaNIjJkydXmwWXnZ3Nddddh9frBSAoKIhzzz23wrxOnTrRo0cP//1777230n0CfT4fL774Ivfdd99BNaWoydH8fhURERGR+qdusCIi4hcVFcWkSZM466yzyMrKoqSkhLvuuounnnqKIUOG0K1bN2JiYiguLiYjI4NVq1Yxb948UlJSgKoz4Xbt2sUDDzzAuHHj6NWrF/369aNdu3bExMRQWlrK5s2bmTZtWkAgpXPnztx4442Vnm/kyJE88sgjlJaWUlBQwKBBg4iPj6dp06bY7Xb/vGnTptG8efPD+AodHu+//z5nnHGGv6Ppzz//zGmnnUZYWBixsbH+TrFgBaImTJhAz549/ceXf44N5aKLLuKRRx7h4YcfBmD16tWccsop9O3bl7POOovWrVsTEhJCbm4uO3fuZOnSpfz+++/k5+cD0K9fvwrnNE2TOXPmMHv2bCIjI+nfvz+9e/emWbNmhIWFkZ2dzfLly/nqq6/IysryH/ePf/yDmJiYStf50EMPMXz4cMDKZOzTpw8jR46kb9++2O12UlJS+Oqrr/wZdY8++qj/OR0uR/v7VURERETql4J1IiISoEePHsybN4+LL76YdevWAVbJ4fvvv1/jsTUFkUzTZPHixSxevLjaeR06dOCHH34gKCio0vHWrVvz8ssvc/vtt/uzq/bu3cvevXsD5tWl/LY+NWvWjJ9++omrr76a33//3f94QUEBBQUF/vuJiYl8+eWXdOrUKeD4yMjIeltrdR566CGaNWvGnXfeSUlJCQALFiyoMcMOan6v5Obm8v333wdkWlbmtttu45///GeV45dddhm33norb775JgAlJSW8//77Fd7PhmHwyCOPMGrUqMMerDva368iIiIiUr9UBisiIhV06NCB5cuX8/rrrwds0l8Zp9PJGWecwfPPP19pJ83zzjuPJ554gv79++Nyuao9V/PmzXn00UdZunQprVq1qnbumDFjWLx4MWPHjqVnz55ER0c3ioyz2mrVqhW//vorEyZM4MILLyQpKQmXy0ViYiKnnXYazz//PKtWraJ///4BWWRgZUA2Frfccgvr16/nL3/5S43riouL4+qrr+brr79m3LhxFcYff/xxbrvtNtq2bVvjdfv378+0adN4/fXXayxdff3113nhhRcCusOW16VLF7755hseeuihGq97sI7296uIiIiI1B/DNE2zoRchIiKN25YtW1iwYAF79uwhOzub0NBQmjRpQseOHenWrRthYWG1Ok9xcTHLli1j48aNpKamUlRUREhICPHx8fTo0YMTTzxRAYxKzJw5k3POOQewymLz8vJwOp0NvKqKPB4PCxcuZN26daSnp1NaWkpERARJSUl06dKFDh061HpPuNTUVFasWEFKSgpZWVl4PB4iIyNp1aoVffr0Oahy0ZKSEn7++WfWrVtHfn4+zZo1o2vXrvTp06fO5xIREREROVIUrBMREWnk7r33Xp577jkATj75ZBYuXNjAKxIRERERkSNFZbAiIiKN2N69ewP2VyvfSVZERERERI49CtaJiIjUs6ysLNavX1/jvPz8fK666ioyMzMBqwnCDTfccKSXJyIiIiIiDUjBOhERkXqWlpZGly5duPzyy5k8eXKFrqDp6el8+OGH9OrVi59++sn/+O233067du3qe7kiIiIiIlKPtGediIhIPVu7di2dO3cOeCwmJobIyEjy8vLIysriwH+eTznlFGbNmlXrZh4iIiIiInJ0UmadiIhIPXM4HBW6omZlZbF161YyMzMDAnU2m43rr7+en376SYE6EREREZHjgDLrGjmfz8euXbuIiIio8MFORESOXjt27GDatGn8/vvvrFu3jl27dpGfn4/dbic2NpbWrVtzxhlncPnll9OpU6eGXq6IiDQCpmmSl5dH8+bNsdkad96FaZq43W58Pl9DL0VEpEHYbDacTudBxXIUrGvkduzYQcuWLRt6GSIiIiIi0khs376dpKSkhl5GpQoLC8nJySEvLw+v19vQyxERaVB2u52IiAiioqIIDQ2t9XGOI7gmOQwiIiIA6x/kyMjIBl6NiIiIiIg0lNzcXFq2bOn/jNDY5OXlsWPHDpxOJ9HR0YSFhWGz2VQhJCLHHdM08fl8FBQUkJubS3Z2NklJSbX+/a1gXSNX9g9bZGSkgnUiIiIiItIog1+FhYXs2LGDyMhImjdv3ijXKCJS38LCwoiPj2fXrl3s2LGD1q1b1yrDrnFvdCAiIiIiIiKNXk5ODk6nU4E6EZEDGIZB8+bNcTqd5OTk1OoYBetERERERETkoJU1voiMjFSgTkSkEoZhEBkZSV5eHrVpHaFgnYiIiIiIiBw0t9uN1+slLCysoZciItJohYaG4vV6cbvdNc5VsE5EREREREQOms/nA8Bm08dLEZGq2O12YP/vzOrot6mIiIiIiIgcMpXAiohUrS6/IxWsExERERERERERaSQUrBMREREREREREWkkFKwTERERERERERFpJBSsExERERERERERaSQUrBMREREREREREWkkFKwTEREREREREalnbdq0wTAM2rRp09BLaTQGDhyIYRjHfXdpR0MvQEREREREREREjj0ffPABW7ZsAeCRRx5p0LUcTRSsExERERERERGRw+6DDz7g559/BhSsqwsF60RERERERERE6llZxpnsN2fOnIZeQqOgPetEREREREREREQaCWXWSY3+OWUFJW4foS47IS4HoS77vq/A2yH7boeVux3itGOzHd8bQ4qIiIiIiIiI1JaCdVKjb5fvJrvQfdDHhzj3Be4OCOSVD/jVZqzsdtnjQQ7bcd8hRkREREREpCrFxcVMnz6dWbNmsWjRIjZs2EB2djbBwcEkJibSr18/Ro0axTnnnFPlOR555BEeffRRAGbPns3AgQP56aefePPNN5k/fz5paWlER0fTu3dvbr75Zi699NIqz7VlyxaSk5MBuP766/nggw/YuXMnr776Kt988w3btm0DoF27dlx22WXcddddREZGVnm+gQMH+vdDM00Tn8/HJ598wmeffcbKlStJS0vD4/FgmmbAcT6fj88++4xJkyaxaNEi9u7dS3BwMC1atOCss87iL3/5C927d69wvZSUFE466SRycnIICgpi3rx59OzZs8r1XXjhhXz33XcAjBs3jieeeCJgvE2bNmzdupXWrVtXWhJb2Ws/d+5cXn/9debOnUtqaioJCQn07duXBx54gJNPPjng+BkzZvDGG2/w559/snv3bmJiYhg4cCD/+Mc/OPHEE6tcN8COHTv4+uuv+eWXX1i+fDnbt2+nuLiYqKgo2rVrx6BBgxg7diwtW7as9PjyP5sylX1+L3sfVHbcgT+3Ay1dupTx48cze/Zsdu7cSXFxMQkJCZx88skMHz6cq6++Gput6oLSyq711VdfMX78eJYuXUp6ejqxsbGceuqp3HXXXQwYMKDa9RxOCtZJjQpLvId0fJHbS5HbCwWHaUH72Az8GX1hFbL+7JWOlb9dMQi4PxDotKtCXEREREREjm5dunQhJSWlwuP5+fls3LiRjRs38sknnzBs2DA++eQTwsPDazznPffcw/PPPx/wWFpaGtOmTWPatGkMHz6czz77DJfLVeO55syZw+WXX05GRkbA40uXLmXp0qW89dZbTJs2rdLA2YGysrK45JJL+OWXX6qdl5KSwiWXXMLy5csDHi8pKSEnJ4fVq1fzxhtvcNddd/Hss88GBHuSk5N56623uOqqqygpKWHEiBEsWbKEsLCwCtd58cUX/YG6fv368dhjj9X4HGryyCOP8NhjjwUEsbZv38727duZMmUKH330ESNHjsTj8XDnnXfy5ptvBhyfmprK559/zuTJk5kyZQpDhw6t9Dpz5sxh0KBBlQbLMjIyyMjIYMGCBTz//PO8/vrr3HTTTYf83OrC6/Xy97//nVdeeaXCGstej6+++opnn32WqVOn0qpVqxrPWVxczHXXXceXX34Z8HhqaipfffUVX331FU8++SQPPPDAYX0uVVGwTqrl8foo9foaehmV8pmQX+Ihv8TD3sN8bqfdCMjsq6zs1z/mdBAWVPm8kIAxB6EqCxYRERERkXpSWFhIdHQ0gwYN4qSTTqJ169aEhoaSm5vL8uXLmThxIrt372bq1KnceOON/O9//6v2fK+88gqTJ08mOjqaG2+8kV69euHxeJg7dy4fffQRJSUlTJo0ieuuu46JEydWe65t27YxfPhwMjMzueiii7jggguIjo5m/fr1fPDBB2zevJmdO3cyaNAg/vzzzyozuMpcc801/PLLL3Tt2pWrr76adu3aUVBQEJDdlZqaSv/+/dm9ezcASUlJjB49mi5dulBUVMTs2bOZMGECXq+XF154gby8PN55552A64wYMYIZM2bw7rvvsn79em6//faAzDCAP//8k/vvvx+AqKgoJkyYgMNxaOGXN998k4kTJ9K8eXNuvPFGunbtSnFxMd9++y2TJk3C6/UyevRoTj31VF544QXefPNNOnTowKhRo2jfvj25ubn873//Y+bMmZSWlnLdddexbt06mjRpUuFaxcXFmKZJx44dOeuss+jSpQtxcXE4HA5SU1P55ZdfmDJlCqWlpdxyyy00bdqUCy+8MOAc//73v0lPT+ef//wnq1atAqystQPVJpB2oJtvvtn/mjscDq666irOOussQkNDWb16Ne+99x47d+5k6dKlnHbaaSxZsoSEhIRqz3nTTTfx5Zdf0rVrV0aOHOl//3z33XdMnjwZgAcffJDTTjuNM888s85rrivDrCmvUBpUbm4uUVFR5OTkVJv+e8SuX+ym+yM/1vt1j2XBTpuV9ee07wvkWUG8UJed0CDrdojLGiubV37MnxUYtH8sLMihsmARERGRY1xDfzaoSnFxMSkpKSQnJxMcHFzt3AcmLWddWl49razx6tg0gqeG15wtdqi+//57zj77bJxOZ6XjhYWFXHvttf4gyq+//srpp58eMKd8KSZAhw4d+Omnn2jRokXAvOXLlzN48GDS09MB+OKLL7j88ssD5pQvgwWw2+188sknXHXVVQHzioqKuOqqq/j6668BuOCCC/j2228rrP/AUsvbb7+dl156CbvdXunzveiii/znOffcc5k0aVKFbMLff/+doUOHkpubC8CUKVMYNmxYwJzCwkJOPvlk1qxZA8Ann3zCNddcA0BBQQG9evVi/fr1AEycOJErr7yy0vXUpQwWYPDgwUyZMqXCmh966CEef/xxAHr37s3ixYsZNWoU7777boUg4ahRo/j4448BeOaZZ7j33nsrXHfr1q1kZ2fTo0ePStcNVvbjeeedx549ezjhhBNYt25dpZ9H61LWWpv5kydPZvjw4QBER0czffp0+vbtGzAnLy+PYcOGMXv2bAAuueSSSgOFB75/7r777grZlAD//e9//cHXCy+8kG+++abG51GZuvyuVLCukWvof5D35pVw/su/UlTqpbDUg0/vlkbLMNgX6NuXzVcukLd/30AHYa79t2vbLMTlUFmwiIiISENr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9BCFhYX88ssv/PLLL1XOj4uLO6jOrAcjKCiImTNnMmbMGD7++GM8Hg9ffPEFX3zxRaXzbbbAQslu3brx1ltvMWbMGDweD7///ju///57wJzY2Fg+++wz/vjjDwXrGjmVwYqIiIgcz2pTIotBXO4azgjeRH5EG2LtxZxobGG9rwUdjJ3+EtmZvv3dY6/Nv5P1GR5/91hM0yqLLc3H3z122n0qixUROUoMHjyYFStWMGbMGNq2bUtQUBDR0dH07duXF154gYULF5KcnNzQy6zRPffcw9atW3n66ac555xzaN68OUFBQQQFBdG0aVP69+/P3/72N7777jt27dpFXFxcva0tJCSEjz76iCVLlnDnnXdy4oknEh0djd1uJyoqip49ezJmzBh++OEHrr322grH33jjjcyfP59rrrmGpKQknE4nsbGx9OzZk3/961+sWLGC8847r96ejxw8wzwS7VnlsMnNzSUqKoqcnBwiIyMbejkiIiJyPDiwi2yZJh0gYz2mzUFeRDvWFoTT2r2JBLK52X0P7Y1djHNO4D+lI0mhGe84n2MP0aT5ouli34EDD4TEQnxH2PaHdU7DDi16Q5+boMsl2j9KpBqN9bNBcXExKSkpJCcn11sWkojI0aYuvyuVWSciIiIigQ7sItuit/V4xnoIjcfweYgsTqWvZzHxtnxWOLow23cSNzq+r9A99htPP7rZtpBhhvOzrwdpxOLbu946n80B+Ky97L4aAy90gXXfN9jTFhEREWkMFKwTERERkcqVlcje8hNc8RFggGHsC7JZxRm2NqfTLcHFb23eI8E4sHtsKJc7frX2s3NfRXP2klC4kZ+L2rK9SX98id2t8tjgKOucZfvZrZrSkM9aREREpEEpWCciIiIiNes6DK76DEyvtfdcSS4YNtg+D2P3UppnL4GkPrSPsTPOZXWPneQ9w7+f3UazOSfYdrHSTOam4rso3puCd9dy69zaz05ERETET8E6EREREamdTufD3aut0tikPoAR0D3WKMggNnc1cbY89kZ05mL7fEwT/s/9F55wvgfAve4xjLTP4gTbLtb6WrLc2wZPSaF1DnsQtO5v3V7wFjzbXmWxIiIictxRsE5EREREaq+W3WMT8tcQb89nZ2hHrrT/4u8eu9VM4CHHx5SaDt7wXOjfz+4XerI7pD3eayZBTFuwu6AkHyZcBd+PU5ad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rJMkKYqlpqaSkpJSft6qVSsGDRoUwYwkSZIk1SSLdZIkRbHrrruOL774ovx869atjB8/PoIZSZIkSapJFuskSYpSU6ZM4dlnnwXgO9/5Dunp6QA888wzPPfcc5FMTZIkSVINscGEJElRaO3atfTu3ZtvvvmGRo0a8f7771NcXEz//v0pKioiMTGRlStX0qlTp0inKkmSJKkaubJOkqQoU1RUxCWXXMI333wDwP/93/+RmZnJCSecwD333ANAQUEBP/jBDygpKYlkqpIkSZKqmcU6SZKizM9+9jM++OADAC644AJ+9KMflY/95Cc/Yfjw4QC899573HHHHRHJUZIkSVLN8DFYSZKiyMyZMzn33HMBaN++PStXrqRp06YVYrKysujVqxebN28mEAjw+uuvc+aZZ0YgW0mSJEnVzWKdJElR4uuvv6ZXr15kZ2cTGxvLggULOOWUU6qMnTdvHmeddRbBYJBWrVrx0Ucf0aJFi1rOWJIkSVJ18zFYSZKiQDAY5LLLLiM7OxuAO++8c7+FOoAzzjiD2267DYCtW7cyduxY/PubJEmSVPe5sk6SJEmSJEmKEq6skyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqKExTpJkiRJkiQpSliskyRJkiRJkqLE/wcEFG+74pfk6QAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot results\n",
    "plot_results(approx_vals, numerical_vals, xs)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "x5jjgwX2AKdI"
   },
   "source": [
    "# Generating prompts & solutions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "FDE4sIXRhSeT"
   },
   "source": [
    "In this section, we provide functions that generate prompts and solutions, and finally, an entire dataset."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "yBe2mfyMc6hj"
   },
   "source": [
    "## Functions"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "D4xg8OnKdAnY"
   },
   "source": [
    "Here we define the functions that we will use to generate the Latex prompts and solutions. Note that to load these prompts and responses in latex, the packages\n",
    "\n",
    "```\n",
    "\\usepackage{minted}\n",
    "\\usepackage{amsmath}\n",
    "```\n",
    "\n",
    "\n",
    "are required."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 673,
   "metadata": {
    "executionInfo": {
     "elapsed": 143,
     "status": "ok",
     "timestamp": 1706814579110,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "gPRNPtRbPVFz"
   },
   "outputs": [],
   "source": [
    "import inspect\n",
    "\n",
    "## Define function to return latex code of a python function\n",
    "def function_to_latex(func):\n",
    "\n",
    "    # Get the source code\n",
    "    source_code = inspect.getsource(func)\n",
    "\n",
    "    # Escape special characters\n",
    "    source_code = source_code.replace(\"\\\\\", \"\\\\\\\\\")\n",
    "    source_code = source_code.replace(\"{\", \"\\\\{\")\n",
    "    source_code = source_code.replace(\"}\", \"\\\\}\")\n",
    "\n",
    "    # Wrap the source code in a minted environment\n",
    "    latex_code = \"\\\\begin{minted}{python}\\n\" + source_code + \"\\\\end{minted}\\n\"\n",
    "\n",
    "    return latex_code"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Generating the problem statement (without \"compare to numerical solution\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 674,
   "metadata": {
    "executionInfo": {
     "elapsed": 3,
     "status": "ok",
     "timestamp": 1706814579717,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "WmqelK2NQN2T"
   },
   "outputs": [],
   "source": [
    "## Define function to generate prompt and integral\n",
    "def generate_problem():\n",
    "\n",
    "  \"\"\"\n",
    "  This function generates a problem statement and returns the statement as well\n",
    "  as the parameters of the integral used in the approximation function.\n",
    "  \"\"\"\n",
    "\n",
    "  # Generate integral\n",
    "  bounds, g, f, sign = generate_integral(generate_linear_combination, generate_bounds, max_num_terms=5, range=[-1,1])\n",
    "\n",
    "  # Formatting problem statement\n",
    "  if sign == 1:\n",
    "    show_sign = \"+\"\n",
    "  else:\n",
    "    show_sign = \"-\"\n",
    "\n",
    "  # Get problem statement\n",
    "  statement = f\"Consider the integral \\\\par \"\\\n",
    "              f\"\\\\begin{{equation}} I(x) = \\\\int_{{{bounds[0]}}}^{{{bounds[1]}}} ({latex(g)}) e^{{{show_sign} x ({latex(f)})}} \\\\, dt \\\\end{{equation}} \\\\par\"\\\n",
    "              f\" Develop an analytical formula for $I(x)$ that is accurate as $x \\\\to \\\\infty$.\"\n",
    "\n",
    "  return bounds, g, f, sign, statement"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Percent error function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 675,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Define function to roughly quantify quality of approximation\n",
    "\n",
    "def get_last_pct_error(approx_vals, numerical_vals):\n",
    "\n",
    "  \"\"\"\n",
    "  This function gets the absolute percent error between the numerical values\n",
    "  and the analytical approximation at the last point (ie the largest x value)\n",
    "  for which numerical integration worked and was nonzero.\n",
    "  \"\"\"\n",
    "\n",
    "  # Get index of last nonzero input to numerical vals\n",
    "  non_zero_indices = np.nonzero(numerical_vals)\n",
    "  last_non_zero_index = non_zero_indices[0][-1]\n",
    "\n",
    "  # Get last numerical value\n",
    "  last_num_val = numerical_vals[last_non_zero_index]\n",
    "\n",
    "  # Get analytical value for this same x\n",
    "  corresponding_approx = approx_vals[last_non_zero_index]\n",
    "\n",
    "\n",
    "  # epsilon = 1e-5  # A small number to prevent division by zero\n",
    "  # Return absolute pct error between them. Add a small number in the denominator to avoid division by zero\n",
    "  return np.abs((corresponding_approx - last_num_val) / (last_num_val)) * 100\n",
    "\n",
    "## Get pct error from many approximations\n",
    "\n",
    "# Define array of xs to test on\n",
    "xs = np.logspace(-1, 3, 300)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Version of function that does not have code in the csv file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 684,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Define function to approximation and response\n",
    "def get_solution(bounds, g, f, sign):\n",
    "\n",
    "  \"\"\"\n",
    "  This function takes in the parameters of the Laplace integral and returns an\n",
    "  analytical approximation as well as a response statement.\n",
    "  \"\"\"\n",
    "\n",
    "  # Determine whether we will look for min or max of f\n",
    "  if sign == 1:\n",
    "    minmax = \"maximum\"\n",
    "    small_large = \"largest\"\n",
    "    show_sign = \"+\"\n",
    "  else:\n",
    "    minmax = \"minimum\"\n",
    "    small_large = \"smallest\"\n",
    "    show_sign = \"-\"\n",
    "\n",
    "  statement = f\"The integral is of the form \\\\begin{{equation}} I(x) = \\\\int_{{a}}^{{b}} g(t) e^{{{show_sign} x f(t)}} \\\\, dt \\\\end{{equation}} \\\\par \"\\\n",
    "              f\"where $a={bounds[0]}$, $b={bounds[1]}$, $g(t) = {latex(g)}$, and $f(t) = {latex(f)}$. \"\\\n",
    "              f\"This means we can use Laplace's method to develop an analytical approximation in the limit that $x \\\\to \\\\infty$. \\\\par \"\\\n",
    "              f\"In this limit, the integral will be dominated by the integrand near the {minmax} of $f(t)$ within the bounds $[{bounds[0]}, {bounds[1]}]$. \"\\\n",
    "              f\"So, to simplify the integral, we will expand the integrand around this {minmax}. \\\\par \"\n",
    "\n",
    "  # Get the analytical approximation of the integral, specifying whether the min/max was on the bounds, if not how many min/max there were\n",
    "  approximation, minmax_on_bounds, num_minmax, analytic_min, minima, critical_points, which_bound = approximate_laplace_integral(bounds, g, f, sign)\n",
    "\n",
    "  # Statement for the case where we could find the min/max of f analytically\n",
    "  if analytic_min:\n",
    "    statement += f\"In this case, we can find the {minmax} of $f(t) = {latex(f)}$ on the interval analytically. We begin by looking for critical points $t_{{crit}}$ of $f(t)$ by solving $f'(t) = {latex(diff(f, t))} = 0$ for $t$. \"\n",
    "\n",
    "    # If critical points were not found.\n",
    "    if len(critical_points) == 0:\n",
    "\n",
    "      statement += f\"We find that there are no critical points of $f(t) \\\\in {bounds[0], bounds[1]}$. This means that its {minmax} must be on the bounds. \"\\\n",
    "                   f\"Comparing the values of $f(t)$ on the lower and upper bounds of the integral, we find that its {minmax} occurs at $t_0 = {which_bound} = {minima[0]}$. \\\\par \"\n",
    "\n",
    "    # If they were\n",
    "    else:\n",
    "        statement += f\"This gives us that $t_{{crit}} = {critical_points}$. To find the {minmax} on this interval, we evaluate $f(t)$ at the critical points $t_{{crit}}$ and at the bounds, ${bounds[0]}$ and ${bounds[1]}$. \"\\\n",
    "                   f\"We select the value of $t$ that gives the {small_large} value for $f(t)$. Here, we find the {minmax} $t_0 = {minima}$. \\\\par \"\n",
    "\n",
    "\n",
    "  # Statement for numerical case\n",
    "  else:\n",
    "\n",
    "    # Statement & code\n",
    "    statement += f\"However, it is impossible to compute the {minmax} of $f(t)$ within these bounds analytically. We, therefore, find the {minmax} numerically with the dual annealing algorithm. \"\\\n",
    "                 f\"Using a few iterations of dual annealing, we find that the {minmax} of $f(t)$ occurs at $t_0 = {minima}$. \\\\par \"\n",
    "\n",
    "\n",
    "  # Statement for case of min/max on bounds of integral\n",
    "  if minmax_on_bounds:\n",
    "\n",
    "    statement += f\"Since the integral is dominated by the value of the integrand near $t_0={which_bound}$, we Taylor expand the integrand around this point: \"\\\n",
    "                 f\"\\\\begin{{equation}} I(x) =  \\\\int_{{a}}^{{b}} (g({which_bound}) + (t-{which_bound})g'({which_bound})+...) e^{{{show_sign} x (f({which_bound}) + (t-{which_bound}) f'({which_bound}) + ...)}} \\\\, dt \\\\end{{equation}} \"\\\n",
    "                 f\"We can then approximate \\\\begin{{equation}} I(x) \\\\approx \\\\int_{{a}}^{{b}} g({which_bound}) e^{{{show_sign} x (f({which_bound}) + (t-{which_bound}) f'({which_bound}))}} \\\\, dt \\\\end{{equation}} \"\\\n",
    "                 f\"Pulling out the constant in the integral gives \"\\\n",
    "                 f\"\\\\begin{{equation}} I(x) \\\\approx g({which_bound}) e^{{{show_sign} x f({which_bound})}} \\\\int_{{a}}^{{b}} e^{{{show_sign} x (t-{which_bound}) f'({which_bound})}}  \\\\, dt \\\\end{{equation}} \\\\par \"\\\n",
    "\n",
    "    # Case where bound is lower bound\n",
    "    if which_bound == \"a\":\n",
    "\n",
    "      # Add additional comment if sign is positive for clarity, since there is a technicality when taking the absolute value\n",
    "      if sign == -1:\n",
    "        statement += f\"We perform the change of variables $u = x (t-{which_bound}) |f'({which_bound})|$, rewriting the integral as \"\n",
    "      else:\n",
    "        statement += f\"We perform the change of variables $u = x (t-{which_bound}) |f'({which_bound})|$. Note that $f'({which_bound}) < 0$ since it is a maximum. Rewriting the integral yields \"\n",
    "\n",
    "      statement += f\"\\\\begin{{equation}} I(x) \\\\approx g(a) e^{{{show_sign} x f(a)}} \\\\int_{{0}}^{{x (b-a) |f'(a)|}} \\\\frac{{1}}{{x |f'(a)|}} e^{{-u}} \\\\, du. \\\\end{{equation}} \"\\\n",
    "                   f\"Since we are interested in a solution for $I(x)$ as $x \\\\to \\\\infty$, we can simplify the integral by approximating the upper bound as \"\\\n",
    "                   f\"\\\\begin{{equation}} I(x) \\\\approx g(a) e^{{{show_sign} x f(a)}} \\\\frac{{1}}{{x |f'(a)|}} \\\\int_{{0}}^{{\\\\infty}} e^{{-u}} \\\\, du. \\\\end{{equation}} \\\\par \"\\\n",
    "                   f\"Solving the integral and evaluating, we find that \\\\par \"\\\n",
    "                   f\"\\\\begin{{equation}} \\\\boxed{{I(x) \\\\approx {latex(approximation)}}}. \\\\end{{equation}} \"\n",
    "\n",
    "    # Case where bound is upper bound\n",
    "    else:\n",
    "\n",
    "      # Add additional comment if sign is positive for clarity, since there is a technicality when taking the absolute value\n",
    "      if sign == -1:\n",
    "        statement += f\"We perform the change of variables $u = x (t-{which_bound}) |f'({which_bound})|$. Note that $f'({which_bound}) < 0$ since it is a minimum. Rewriting the integral yields \"\n",
    "      else:\n",
    "        statement += f\"We perform the change of variables $u = x (t-{which_bound}) |f'({which_bound})|$, rewriting the integral as \"\n",
    "\n",
    "\n",
    "      statement += f\"\\\\begin{{equation}} I(x) \\\\approx g(b) e^{{{show_sign} x f(b)}} \\\\int_{{x (a-b) |f'(b)|}}^{{0}} \\\\frac{{1}}{{x |f'(b)|}} e^{{u}} \\\\, du. \\\\end{{equation}} \"\\\n",
    "                   f\"Since we are interested in a solution for $I(x)$ as $x \\\\to \\\\infty$, we can simplify the integral by approximating the lower bound as \"\\\n",
    "                   f\"\\\\begin{{equation}} I(x) \\\\approx g(b) e^{{{show_sign} x f(b)}} \\\\frac{{1}}{{x |f'(b)|}} \\\\int_{{-\\\\infty}}^{{0}} e^{{u}} \\\\, du. \\\\end{{equation}} \\\\par \"\\\n",
    "                   f\"Solving the integral and evaluating, we find that \\\\par \"\\\n",
    "                   f\"\\\\begin{{equation}} \\\\boxed{{I(x) \\\\approx {latex(approximation)}}}. \\\\end{{equation}} \"\n",
    "\n",
    "  # Statement for case where min/max not on bounds\n",
    "  else:\n",
    "\n",
    "    statement += f\"Since the integral is dominated by the value of the integrand near {minima[0]}, we Taylor expand the integrand around this point: \"\\\n",
    "                 f\"\\\\begin{{equation}} I(x) =  \\\\int_{{a}}^{{b}} (g({minima[0]}) + (t-{minima[0]})g'({minima[0]})+...) e^{{{show_sign} x (f({minima[0]}) + (t-{minima[0]}) f'({minima[0]}) + \\\\frac{{(t-{minima[0]})^2}}{{2}} f''({minima[0]}) +...)}} \\\\end{{equation}}\"\\\n",
    "                 f\"But $f'({minima[0]}) = 0$ by definition, so we can remove this term from the exponent. We can then approximate \\\\begin{{equation}} I(x) \\\\approx \\\\int_{{a}}^{{b}} g({minima[0]}) e^{{{show_sign} x (f({minima[0]}) + \\\\frac{{(t-{minima[0]})^2}}{{2}} f''({minima[0]}))}} \\\\, dt, \\\\end{{equation}} \\\\par \"\\\n",
    "                 f\"which equals \\\\par \"\\\n",
    "                 f\"\\\\begin{{equation}} g({minima[0]}) e^{{{show_sign} x f({minima[0]})}} \\\\int_{{a}}^{{b}} e^{{{show_sign} x (\\\\frac{{(t-{minima[0]})^2}}{{2}} f''({minima[0]}))}} \\\\, dt. \\\\end{{equation}} \\\\par \"\\\n",
    "                 f\"We perform the change of variables $u = \\\\sqrt{{x \\\\frac{{|f''({minima[0]})|}}{{2}}}}(t-{minima[0]})$, rewriting the integral as \"\\\n",
    "                 f\"\\\\begin{{equation}} g({minima[0]}) e^{{{show_sign} x f({minima[0]})}} \\\\int_{{\\\\sqrt{{x \\\\frac{{|f''({minima[0]})|}}{{2}}}} (a-{minima[0]})}}^{{\\\\sqrt{{x \\\\frac{{|f''({minima[0]})|}}{{2}}}} (b-{minima[0]})}} \\\\sqrt{{\\\\frac{{2}}{{x |f''({minima[0]})|}}}} e^{{-u^2}} \\\\, du. \\\\end{{equation}} \\\\par \"\\\n",
    "                 f\"Since we are interested in a solution for $I(x)$ as $x \\\\to \\\\infty$, we can simplify the integral by approximating the bounds as \"\\\n",
    "                 f\"\\\\begin{{equation}} g({minima[0]}) e^{{{show_sign} x f({minima[0]})}} \\\\sqrt{{\\\\frac{{2}}{{x |f''({minima[0]})|}} }} \\\\int_{{-\\\\infty}}^{{\\\\infty}} e^{{-u^2}} \\\\, du. \\\\end{{equation}} \\\\par \"\n",
    "\n",
    "    # Case where there was one min/max\n",
    "    if num_minmax == 1:\n",
    "\n",
    "      statement += f\"Solving this integral and evaluating, we find that \\\\par \"\\\n",
    "                   f\"\\\\begin{{equation}} \\\\boxed{{I(x) \\\\approx {latex(approximation)}}}. \\\\end{{equation}}\"\n",
    "\n",
    "    # Case where there were multiple\n",
    "    else:\n",
    "\n",
    "      statement += f\"Note that here, while we ignored them in the work above, there were actually multiple $t_0$ values. \"\\\n",
    "                   f\"This means that to get the final approximation, we need to add up all the contributions of this form, one for each peak of the integrand near each $t_0$. \\\\par \"\\\n",
    "                   f\"Summing up all these contributions and evaluating gives us a final approximation of \\\\par \"\\\n",
    "                   f\"\\\\begin{{equation}} \\\\boxed{{I(x) \\\\approx {latex(approximation)}}}. \\\\end{{equation}}\"\n",
    "\n",
    "  return approximation, statement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 685,
   "metadata": {
    "executionInfo": {
     "elapsed": 4,
     "status": "ok",
     "timestamp": 1706814581442,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "mTT8EcXgdLx0"
   },
   "outputs": [],
   "source": [
    "## Define function to generate dataset\n",
    "def generate_dataset(n, filename, pct_error_limit):\n",
    "\n",
    "  \"\"\"\n",
    "  This function generates a csv file called filename with n prompts and solutions\n",
    "  and saves it to the specified path.\n",
    "\n",
    "  It excludes any approximations that give zero, as we need higher order terms\n",
    "  to get any information from these integrals using the Laplace method.\n",
    "  \"\"\"\n",
    "\n",
    "  current_path = os.getcwd()\n",
    "\n",
    "  xs = np.logspace(-1, 3, 300)\n",
    "  data = []\n",
    "\n",
    "  for i in range(n):\n",
    "\n",
    "    # Generate integral and prompt\n",
    "    bounds, g, f, sign, prompt = generate_problem()\n",
    "\n",
    "    # Generate solution and statement\n",
    "    approximation, solution_statement = get_solution(bounds, g, f, sign)\n",
    "\n",
    "    # Skip approximations that give zero. Laplace method to first order gives no information\n",
    "    if approximation == 0:\n",
    "      continue\n",
    "\n",
    "    # Skip NaN approximations, which occur when f'(t_0) == 0 for t_0 on the bounds\n",
    "    elif type(approximation) == sp.core.numbers.NaN:\n",
    "      continue\n",
    "\n",
    "    boxed_solution = f\"\\\\boxed{{I(x) \\\\approx {latex(approximation)}}}\"\n",
    "\n",
    "    # plot_results(approx_vals, numerical_vals, xs)\n",
    "\n",
    "    # this version only returns the ones without an error\n",
    "    numerical_vals, num_vals = integrate_numerically(bounds, g, f, sign, xs, max_error=1000)\n",
    "\n",
    "    # Computes the approximate value num_vals times; up to the point where the integration error overflows\n",
    "    approx_vals = evaluate_analytical(approximation, xs, max_val=10**90)[:num_vals]\n",
    "\n",
    "    error = get_last_pct_error(approx_vals, numerical_vals)\n",
    "\n",
    "    # computing the large x approx and numerical solutions\n",
    "    # the last x value at which the expressions are calculated\n",
    "    \n",
    "    # large_x_eval_point = xs[num_vals - 1]\n",
    "    # large_x_numerical_eval = numerical_vals[num_vals - 1]\n",
    "\n",
    "    non_zero_indices = np.nonzero(numerical_vals)\n",
    "    last_non_zero_index = non_zero_indices[0][-1]\n",
    "    large_x_eval_point = xs[last_non_zero_index]\n",
    "    large_x_numerical_eval = numerical_vals[last_non_zero_index]\n",
    "    large_x_approx_eval = approx_vals[last_non_zero_index]\n",
    "\n",
    "    # large_x_eval_point = xs[:num_vals][-1]\n",
    "    # large_x_numerical_eval = numerical_vals[:num_vals][-1]\n",
    "    # large_x_approx_eval = approx_vals[-1]\n",
    "    \n",
    "    if error <= pct_error_limit:\n",
    "      # Save\n",
    "      data.append([prompt, solution_statement, boxed_solution, large_x_approx_eval, large_x_numerical_eval, large_x_eval_point])\n",
    "      print(f\"{i+1} complete\")\n",
    "    else:\n",
    "      print(f\"{i+1} Error exceeded: {error}%\")\n",
    "\n",
    "  # Convert to array\n",
    "  data = np.array(data)\n",
    "\n",
    "  # Save array as csv file to path\n",
    "  full_path = os.path.join(current_path, filename)  # Combine directory with filename\n",
    "  data_df = pd.DataFrame(data, columns=[\"Prompt\", \"Solution\", \"Boxed Solution\",\\\n",
    "    \"Large x approximate solution\", \"Large x numerical solution\", \"Large x evaluation point\"])\n",
    "  data_df.to_csv(full_path, index=False)\n",
    "\n",
    "  # Return data\n",
    "  return data_df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "hBxUrIdUhGiN"
   },
   "source": [
    "## Testing"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "aGZokrP1hIiu"
   },
   "source": [
    "Here we test the prompt and solution generation."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "L_ZzPC-DolWH"
   },
   "source": [
    "### Qualitative test of approximation accuracy"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "-UsTnbouopr-"
   },
   "source": [
    "Here we test prompt, response, and plot generation by inspection."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 686,
   "metadata": {
    "executionInfo": {
     "elapsed": 680,
     "status": "ok",
     "timestamp": 1706814585882,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "NU7Q4SkjhIRt"
   },
   "outputs": [],
   "source": [
    "# Generate integral and prompt\n",
    "bounds, g, f, sign, prompt = generate_problem()\n",
    "\n",
    "# Generate solution and statement\n",
    "approximation, statement = get_solution(bounds, g, f, sign)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 687,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 69
    },
    "executionInfo": {
     "elapsed": 11,
     "status": "ok",
     "timestamp": 1706814585883,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "fdjesqxvlezd",
    "outputId": "f44a7d54-e310-4970-b1cf-80d5b4af9a21"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Consider the integral \\\\par \\\\begin{equation} I(x) = \\\\int_{-0.7}^{0.5} (- 1.3 t^{3}) e^{- x (- 2.3 t^{5} + 2.6 t^{2} - 2.7 t - 1.5 \\\\sin{\\\\left(t \\\\right)})} \\\\, dt \\\\end{equation} \\\\par Develop an analytical formula for $I(x)$ that is accurate as $x \\\\to \\\\infty$.'"
      ]
     },
     "execution_count": 687,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "prompt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 688,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 137
    },
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1706814586803,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "wjILGOYtZXlt",
    "outputId": "dc81e79b-6cbb-4e0d-94bc-d138bc047f2a"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"The integral is of the form \\\\begin{equation} I(x) = \\\\int_{a}^{b} g(t) e^{- x f(t)} \\\\, dt \\\\end{equation} \\\\par where $a=-0.7$, $b=0.5$, $g(t) = - 1.3 t^{3}$, and $f(t) = - 2.3 t^{5} + 2.6 t^{2} - 2.7 t - 1.5 \\\\sin{\\\\left(t \\\\right)}$. This means we can use Laplace's method to develop an analytical approximation in the limit that $x \\\\to \\\\infty$. \\\\par In this limit, the integral will be dominated by the integrand near the minimum of $f(t)$ within the bounds $[-0.7, 0.5]$. So, to simplify the integral, we will expand the integrand around this minimum. \\\\par However, it is impossible to compute the minimum of $f(t)$ within these bounds analytically. We, therefore, find the minimum numerically with the dual annealing algorithm. Using a few iterations of dual annealing, we find that the minimum of $f(t)$ occurs at $t_0 = [0.5]$. \\\\par Since the integral is dominated by the value of the integrand near $t_0=b$, we Taylor expand the integrand around this point: \\\\begin{equation} I(x) =  \\\\int_{a}^{b} (g(b) + (t-b)g'(b)+...) e^{- x (f(b) + (t-b) f'(b) + ...)} \\\\, dt \\\\end{equation} We can then approximate \\\\begin{equation} I(x) \\\\approx \\\\int_{a}^{b} g(b) e^{- x (f(b) + (t-b) f'(b))} \\\\, dt \\\\end{equation} Pulling out the constant in the integral gives \\\\begin{equation} I(x) \\\\approx g(b) e^{- x f(b)} \\\\int_{a}^{b} e^{- x (t-b) f'(b)}  \\\\, dt \\\\end{equation} \\\\par We perform the change of variables $u = x (t-b) |f'(b)|$. Note that $f'(b) < 0$ since it is a minimum. Rewriting the integral yields \\\\begin{equation} I(x) \\\\approx g(b) e^{- x f(b)} \\\\int_{x (a-b) |f'(b)|}^{0} \\\\frac{1}{x |f'(b)|} e^{u} \\\\, du. \\\\end{equation} Since we are interested in a solution for $I(x)$ as $x \\\\to \\\\infty$, we can simplify the integral by approximating the lower bound as \\\\begin{equation} I(x) \\\\approx g(b) e^{- x f(b)} \\\\frac{1}{x |f'(b)|} \\\\int_{-\\\\infty}^{0} e^{u} \\\\, du. \\\\end{equation} \\\\par Solving the integral and evaluating, we find that \\\\par \\\\begin{equation} \\\\boxed{I(x) \\\\approx - \\\\frac{0.0761079974565744 e^{1.4910133079063 x}}{x}}. \\\\end{equation} \""
      ]
     },
     "execution_count": 688,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "statement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 689,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 592
    },
    "executionInfo": {
     "elapsed": 25465,
     "status": "ok",
     "timestamp": 1706814616206,
     "user": {
      "displayName": "Kaylie Hausknecht",
      "userId": "04194977309324938073"
     },
     "user_tz": 300
    },
    "id": "T1Hmhga1ZQtc",
    "outputId": "0507d421-4737-4ae4-b433-718c8685736b"
   },
   "outputs": [],
   "source": [
    "## Compare analytical approximation and numerical solution\n",
    "\n",
    "# Define array of xs to test on\n",
    "xs = np.logspace(-1, 3, 300)\n",
    "\n",
    "# Get numerical solution\n",
    "# this version only returns the ones without an error\n",
    "numerical_vals, num_vals = integrate_numerically(bounds, g, f, sign, xs, max_error=1000)\n",
    "\n",
    "# Get analytical approximation\n",
    "# Computes the approximate value num_vals times; up to the point where the integration error overflows\n",
    "approx_vals = evaluate_analytical(approximation, xs, max_val=10**90)[:num_vals]\n",
    "\n",
    "# Plot results\n",
    "#plot_results(approx_vals, numerical_vals, xs)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Vx6x27DhcuSx"
   },
   "source": [
    "### Quantitative test of approximation accuracy"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "112ln8JdcuS3"
   },
   "source": [
    "Here, we use the absolute percent error between $I(x)$ and its approximation at the largest value of x we computed with reasonable numerical accuracy to get a rough quantitative estimate of the quality of our approximations."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 690,
   "metadata": {
    "id": "1VURKtNmcuS3"
   },
   "outputs": [],
   "source": [
    "## Define function to roughly quantify quality of approximation\n",
    "def get_last_pct_error(approx_vals, numerical_vals):\n",
    "\n",
    "  \"\"\"\n",
    "  This function gets the absolute percent error between the numerical values\n",
    "  and the analytical approximation at the last point (ie the largest x value)\n",
    "  for which numerical integration worked and was nonzero.\n",
    "  \"\"\"\n",
    "\n",
    "  # Get index of last nonzero input to numerical vals\n",
    "  non_zero_indices = np.nonzero(numerical_vals)\n",
    "  last_non_zero_index = non_zero_indices[0][-1]\n",
    "\n",
    "  # Get average over last 5 numerical values\n",
    "  last_num_val_avg = np.average(numerical_vals[last_non_zero_index-5:last_non_zero_index])\n",
    "\n",
    "  # Get average over last 5 analytical values for this same x\n",
    "  corresponding_approx_avg = np.average(approx_vals[last_non_zero_index-5:last_non_zero_index])\n",
    "\n",
    "\n",
    "  # epsilon = 1e-5  # A small number to prevent division by zero\n",
    "  # Return absolute pct error between them. Add a small number in the denominator to avoid division by zero\n",
    "  return np.abs((corresponding_approx_avg - last_num_val_avg) / (last_num_val_avg)) * 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 691,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "M2vFuFDzcuS3",
    "outputId": "df7fd74a-d084-4b17-c1ba-caafa8ee2605"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "85.2473769622516\n",
      "2.66239545918381\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABNkAAAJTCAYAAAA108BjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAADQR0lEQVR4nOzdeVzU5fr/8dcMDiAKqKCIS0q5IGYammulmbsZZhZGmWZ1bLHFU7+201Gz7zlmi7boSW2zLJU8Lriba6XmhrmSqIk7grgAimwzn98fc5xAdgQG5P18PObRZ7nv+3MNzFHnOvd9XybDMAxERERERERERESk2MzODkBERERERERERKSiU5JNRERERERERETkOinJJiIiIiIiIiIicp2UZBMREREREREREblOSrKJiIiIiIiIiIhcJyXZRERERERERERErpOSbCIiIiIiIiIiItdJSTYREREREREREZHrpCSbiIiIiIiIiIjIdVKSTUREyr1x48ZhMpkwmUx069bN2eFIBXf1s2QymdiwYYOzwxERERGRG0QVZwcgIlJZHT16lICAgFIZe+zYsYwbN65Uxr4eH3/8MRcvXgRg4MCBtGnTxqnxiORHn1cRERERKQol2UREpMx8/PHHHDt2DIDGjRsraSHlmj6vIiIiIlIUSrKJiDiJxWLhlltuKbBdfHw8ycnJjvPC9KlVq9Z1xSYiIiIiIiJFoySbiIiT1K9fn8OHDxfYbvjw4Xz77beO88L0udGMGzeuXC5/FRERERERuUqFD0RERERERERERK6TZrKJiNygbDYb27ZtIzo6mri4OCwWC/7+/tx1113Ur1+/WGMeOHCAnTt3EhcXx+XLl3F3d6dmzZoEBATQpk2bcr1MNSMjgw0bNnDkyBEuXLiAr68v7du357bbbiv2mDt37mTXrl3Ex8fj4+NDQEAAXbt2xWKxlGDkRWO1Wtm0aRNHjhzhzJkzVK1alZCQEBo3bpxnn8TERH799VdOnTrF+fPnHb/Trl274u7uXuQYUlNTiYyMZP/+/Vy4cIHMzEyqVauGv78/TZo04bbbbnPqz0hEREREpFQYIiJSrg0bNswAHK+CJCUlGW+++aZRu3btbP2uvkwmk3H33XcbO3bsKHQM33//vREUFJTreFnHbdWqlTFlypRsfb/55pt8++X2iomJyTbG2LFjHfe6du2aZ5xZ2zVq1MgwDMOw2WzGxIkTjTp16uT6rDZt2hi//fZboX8WhmEYP/30kxEYGJjreH5+fsbEiRMNm81mGIaR7d769euL9Jy8XPszNQzDsFqtxnvvvWfUrVs3R0zffPNNruPs3r3b6N+/v2GxWHJ9L9WqVTNeeukl4+LFi4WK6+LFi8ZLL71keHt75/v7rVq1qtG/f39j586duY6T9TM/bNiwQj07JiYm389QVvn9Tkri8yoiIiIilZOWi4qI3EB27txJ8+bNmTBhAmfPns21jWEY/PLLL7Rv355p06blO55hGDz99NM89thjREVFFdh27969fPPNN8WOv6SlpaVx33338frrrxMfH59rm127dtG9e3fWr19fqDHfe+89evXqxYEDB3K9HxcXx+uvv84DDzxAZmZmsWMvivT0dPr06cMbb7zBmTNnCtXnX//6F7fffjvLli0jIyMj1zaXL1/mk08+4bbbbitwL8Djx49z++2388knn5CYmJhv2ytXrrBs2TI2bdpUqFhFRERERCoCLRcVEblBbNu2jR49emSrRHrrrbdy3333ERAQgNVqZc+ePYSHh3PhwgVsNhvPPvssXl5ehIWF5TrmtGnT+PLLLx3nNWrUICQkhNtuu41atWqRnp5OQkICe/fuZf369cTFxeUYw8vLy1ER9dixY47EU506dfD09Mz1uSW1lPC5555j+fLlAPTo0YN7772XOnXqcO7cORYvXszGjRsBe9Jn6NCh/PHHH3nGBPDtt9/y5ptvOs5NJhM9evSgZ8+e1KpVi9jYWJYsWcK2bduIiIjgnXfeKZH3UZC///3vrF69GoD27dvTr18/GjRoQGJiItu2bcPV1TVb+zfeeIOJEyc6zqtUqULfvn2588478fX15fz586xZs4ZVq1YB9gRat27d2LVrF76+vjmebxgGoaGhxMTEOK61bNmSfv36cfPNN1O1alWSk5M5ceIEkZGR/Prrr6Snp5fGj+K6OfPzKiIiIiIVnHMn0omISEEKs1w0KSnJuPnmm7Mtx/vuu+8cSxazio+PN7p16+ZoW7NmTeP06dO5jtuoUSNHu7vuusu4cOFCnnFarVZj7dq1xmuvvZZnm6zj5bWEMTfFWS5qMpkMwKhdu7bx66+/5tp+4sSJ2X62H3/8cZ5jnzlzxqhRo4ajraenp7F69epc23711VeGi4uLYTaby2S5KGC4ubkZc+fOLbDv0qVLs/W7/fbbjejo6FzbrlmzxvDy8nK0DQ0NzbXdunXrso350Ucf5RtDYmKi8dlnnxnz58/P9b4zl4tmVdzPq4iIiIhUTlouKiJyA/j3v//NkSNHADCbzcyfP5+hQ4diMplytK1duzZLly6lSZMmAFy4cIFJkyblaHfkyBGOHTvmOJ86dSo1atTIMwaz2Uz37t2zzZByJsMwsFgsrFy5kjvvvDPXNq+99hpdu3Z1nM+ZMyfP8SZNmsTFixcd57Nnz6ZHjx65th0xYgTvvfceNputeMEXwxdffEFoaGi+bTIzM3n22Wcd582bN2fDhg00a9Ys1/b33nsv8+bNc5yHh4ezf//+HO2yLrUNDg7m73//e75xeHl5MWrUKAYNGpRvOxERERGRikRJNhGRCu7KlSvMmDHDcT5s2DD69u2bb59q1aplS4bNnDkzx75c1+7tdTUpV5H87W9/Izg4ON82Tz31lON4165due6jZrVa+e677xznvXr14r777st33Jdffpmbb765iBEXzx133MHQoUMLbDd//nxOnDjhOJ8+fTpeXl759unVqxcDBgxwnGf9rF2V9bNSET8nIiIiIiIlQUk2EZEK7qeffuL8+fOO85deeqlQ/UJCQhwJloSEBHbv3p3tvoeHR7bzLVu2XGekZe/xxx8vsE2HDh0cx2lpaRw9ejRHmz179mRLJA0fPrzAcatUqcKjjz5aqDivV2ESbABz5851HLdp0ybbLL7Cjr927doc97N+ViIjI/MspCAiIiIiciNTkk1EpILLWqGxbt26tG7dulD9XFxcss3y2r59e7b7gYGBuLu7O86HDRvGunXrrjPasmOxWLj99tsLbFevXr1s51mXhF4VGRmZ7fzuu+8uVAyFbXe9OnXqVKh2mzdvdhz36dOn0OO3b9/ecfzHH39w6dKlbPez/pz//PNPHn30UU6fPl3o8UVEREREbgRKsomIVHBZZ6C1aNGiSH39/PwcxydPnsx2z93dPdtMsBMnTnDvvfcSGBjI66+/zqpVq7JVMi1vatWqVaiqj9WqVct2fvny5RxtslbN9PT0pH79+oWKoai/j+K6Wg0zP7GxscTHxzvOixJb1s+JzWYjNjY22/0HH3wQHx8fx/m8efNo1KgRffr04eOPP2bXrl1luj+diIiIiIgzKMkmIlLBnTt3znG8fv16TCZToV/h4eGOvrnN4Prggw9o27ZttmvR0dG8//779OnTh1q1atGlSxc++OAD4uLiSu09FkfWWXhFYRhGjmuJiYmO45o1axZ6rPwKRZQkT0/PAttk/ZyAfWZiYT8nVatWzdb32s9K9erVmTNnTrZlo5mZmaxatYrRo0dz++234+vry8MPP8zChQtz3fdORERERKSiU5JNRKSCy5oAuh4pKSk5rnl5efHrr7/yz3/+M9fkUmZmJps3b+a1114jICCAsWPHYrVaSySe8iQtLc1x7OrqWuh+bm5upRFODlWqVCmwTUl9TiD3z0rPnj3ZsWMHAwYMwGzO+c+LCxcuMG/ePAYNGkTLli2zVSQVEREREbkRFPyvchERKdeyzh7y9vbG19e3WOPUqVMn1+tVq1Zl/PjxvPXWW/z000+sWbOGX3/9lT179mRbAnjlyhXGjx/PgQMHss2QuxFkrcB57X5k+SlPy2mvLWTRoEGDYicB85ol2KJFCxYvXsyJEydYtmwZ69ev59dff82xvPTgwYP07NmTBQsWcP/99xcrBhERERGR8kZJNhGRCi7rXlj9+/fnhx9+KJXnuLu7c//99zuSIhcuXGDVqlV8//33LF++3LHM8scff+SRRx5h4MCBpRKHM2RNXJ49e5bU1NRCLUe9dp87Z8r6OQH4+uuv6dmzZ6k8q2HDhjzzzDM888wzgL1YQkREBF9++SV//vknAFarlZEjR9KrV68cP0uTyVTkZ165cuX6AxcRERERuQ5aLioiUsE1b97ccXzgwIEye27NmjUZMmQIS5cuJSIiItsSwTlz5pRZHGWhVatWjmOr1crevXsL1e/3338vrZCKrF69elSvXt1xXpaflRYtWvDGG2/wxx9/EBYW5rh+5syZXJeNZp11l9vS1NyUtz0BRURERKTyUZJNRKSC69q1q+P4999/z7E0rywMGDAg27K/P/74I9d2Wat9VqRqk+3bt882uyoiIqJQ/RYtWlRKERVdlSpV6NKli+N8+fLlZR6DxWJh6tSp2X6WuX1WshaMOH36dKHG3rJly3XHd62K+nkVEREREedQkk1EpILr06ePo7qkYRh89NFHTomjWbNmjuO8qkdmnUlVkhvxl7Y6derQvXt3x/n06dNzrcaa1R9//MGSJUtKObKieeihhxzHq1atYs+ePWUeQ40aNahdu7bjPLfPStbP0q5du0hNTc13TMMw+Pbbb0suyP+pqJ9XEREREXEOJdlERCq4GjVqMHLkSMf5J598wurVq4s0Rm5JjDNnzpCenl7oMbIuoWzUqFGubbJe37dvXxEidL5Ro0Y5jhMSEnjyySfznN106dIlhg4dmmey0VmGDh1K/fr1AXti6rHHHitycYbcPivHjh0rdP/Y2FjOnTvnOM/ts9KhQwfH8eXLlwsspDFp0qRSWf5akT+vIiIiIlL2lGQTEbkBvP3229xyyy2AfWbQgAED+PTTTwtMku3Zs4dXX301W1LjqpUrVxIQEMDEiRML3MB/6tSprFixwnGeV8XIrM8JDw/PdT+u8mrgwIH07t3bcb5gwQK6d+/Ob7/95rhmtVpZsWIF7du3JzIykhYtWjgj1Dy5urry+eefO5Zr7t27l44dO7Jt27Z8+6WmprJ48WL69OnDxIkTc9wfPnw43bt3Z8GCBfnOOrt48SJDhw7FarUC4ObmRq9evXK0CwwMpHXr1o7zV199Ndd98Gw2Gx9//DGvvfZasYolFKQif15FREREpOypuqiIyA3A29ub+fPnc88993DhwgXS0tJ46aWXeO+99+jTpw+tWrWiZs2apKamcu7cOfbv38+WLVuIiYkB8p55dvr0ad544w3efPNNgoOD6dixI7fccgs1a9YkPT2dI0eOsHz58mwJkBYtWjBixIhcxwsLC2PcuHGkp6dz+fJlunfvTu3atfHz88PFxcXRbvny5dSrV68Ef0Il45tvvuGuu+5yVMj8+eef6dy5M9WqVaNWrVqOyqNgTyDNmTOHNm3aOPpnfY/OMmDAAMaNG8fYsWMBiIqKokOHDrRv35577rmHRo0aUbVqVZKSkjh16hS7du1i8+bNXLp0CYCOHTvmGNMwDDZs2MD69evx8vKiS5cutG3bFn9/f6pVq8bFixfZs2cPCxcu5MKFC45+//jHP6hZs2aucY4ZM4YHH3wQsM8cvOOOOwgLC6N9+/a4uLgQExPDwoULHTPY3nnnHcd7KikV/fMqIiIiImVLSTYRkRtE69at2bJlC/fffz/R0dGAfWneN998U2DfgpI/hmEQGRlJZGRkvu2aNWvGypUrcXNzy/V+o0aN+PTTT3n++ecds5nOnj3L2bNns7UryjLVsuTv78+6det45JFH2Lx5s+P65cuXuXz5suO8bt26/Pe//yUwMDBbfy8vrzKLNT9jxozB39+fF154gbS0NAC2bdtW4Iw2KPizkpSUxIoVK7LNbMzNs88+y9tvv53n/UGDBvHMM88wbdo0ANLS0vjmm29yfJ5NJhPjxo3j8ccfL/EkW0X/vIqIiIhI2dJyURGRG0izZs3Ys2cP//nPf7JtHp8bi8XCXXfdxaRJk3KtzNi7d2/+/e9/06VLF1xdXfMdq169erzzzjvs2rWLm266Kd+2I0eOJDIykueee442bdpQo0aNcjHDq7Buuukmfv31V+bMmcN9991HgwYNcHV1pW7dunTu3JlJkyaxf/9+unTpkm3WFthnHJYXTz/9NAcPHuRvf/tbgXH5+vryyCOPsHjxYt58880c9999912effZZbr755gKf26VLF5YvX85//vOfApd4/uc//2Hy5MnZqo1mFRQUxJIlSxgzZkyBzy2uiv55FREREZGyYzIMw3B2ECIiUjqOHj3Ktm3biI+P5+LFi3h4eODj40Pz5s1p1aoV1apVK9Q4qamp7N69m8OHD3PmzBmuXLlC1apVqV27Nq1bt+bWW29V4iEXa9asoWfPnoB9+WhycjIWi8XJUeWUmZnJ9u3biY6OJiEhgfT0dDw9PWnQoAFBQUE0a9as0HuenTlzhr179xITE8OFCxfIzMzEy8uLm266iTvuuKNYyyrT0tL4+eefiY6O5tKlS/j7+9OyZUvuuOOOIo8lIiIiIlJalGQTEREpJa+++iofffQRAO3atWP79u1OjkhEREREREqLlouKiIiUgrNnz2bbPyxrZVIREREREbnxKMkmIiJSSBcuXODgwYMFtrt06RJDhgzh/PnzgH1z/ieeeKK0wxMRERERESdSkk1ERKSQ4uLiCAoKYvDgwSxYsCBHlcmEhAS+/fZbgoODWbduneP6888/zy233FLW4YqIiIiISBnSnmwiIiKFdODAAVq0aJHtWs2aNfHy8iI5OZkLFy5w7V+rHTp0YO3atYUuMiEiIiIiIhWTZrKJiIgUUpUqVXJU2bxw4QLHjh3j/Pnz2RJsZrOZYcOGsW7dOiXYREREREQqAc1kKyU2m43Tp0/j6emZ4wuZiIhUXCdPnmT58uVs3ryZ6OhoTp8+zaVLl3BxcaFWrVo0atSIu+66i8GDBxMYGOjscEVEpBwwDIPk5GTq1auH2Vy+5zkYhkFGRgY2m83ZoYiIOIXZbMZisRQrl6MkWyk5efIkDRs2dHYYIiIiIiJSTpw4cYIGDRo4O4xcpaSkkJiYSHJyMlar1dnhiIg4lYuLC56ennh7e+Ph4VHoflVKMaZKzdPTE7D/Rerl5eXkaERERERExFmSkpJo2LCh4ztCeZOcnMzJkyexWCzUqFGDatWqYTabtSJHRCodwzCw2WxcvnyZpKQkLl68SIMGDQr957eSbKXk6l9IXl5eSrKJiIiIiEi5TFqlpKRw8uRJvLy8qFevXrmMUUSkrFWrVo3atWtz+vRpTp48SaNGjQo1o618bwggIiIiIiIipSYxMRGLxaIEm4jINUwmE/Xq1cNisZCYmFioPjdckm3nzp28//77PPTQQzRu3BiTyYTJZOLo0aN59pkxYwahoaG0aNGCWrVqYbFY8PPz47777mPp0qVlF7yIiIiIiEgZuVqQwcvLSwk2EZFcmEwmvLy8SE5OpjAlDW645aLjx48nIiKiSH0mTZrEn3/+SatWrejSpQseHh4cOXKEZcuWsWzZMl555RU+/PDDUopYRERERESk7GVkZGC1WqlWrZqzQxERKbc8PDw4d+4cGRkZuLq65tv2hkuyderUiVatWtGuXTvatWtH27ZtiYuLy7fPN998Q6tWrahevXq26xs3bqRPnz589NFHPPTQQ3To0KE0QxcRERERESkzNpsNALP5hlvgJCJSYlxcXIC//szMzw2XZHv99deL3KdTp065Xr/zzjsJDQ3l66+/Zu3atUqyiYiIiIjIDUdLRUVE8laUPyP1f1kUwGKxAODm5ubkSEREREREREREpLwqdpLNarWyb98+Zs6cyQsvvECnTp3w8PBwFBoYPnx4scaNiIhg8ODBNGrUCHd3d+rUqUOnTp14//33C13NoaTs2rWL8PBwXFxc6NOnT5k+W0REREREREREKo5iLxd9+OGHWbBgQYkFkpycTFhYWI5qnmfPnuXs2bNs2bKFzz77jPDwcDp37lxiz83qm2++4eeffyY9PZ1jx47x22+/YbFY+Pzzz2nZsmWpPFNERERERERERCq+YifZrFZrtvNatWrh4+PDoUOHijxWZmYmDz74IKtXrwbAz8+Pp59+mqCgIM6fP8+cOXPYtGkTJ0+epH///mzcuLFUkl6bNm3i22+/dZx7eHjw6aef8sQTT5T4s0RERERERERE5MZR7OWi7du35403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vw6At7c3c+bMoUqV60ubTJs2jfDwcOrVq8eIESNo2bIlqampLF26lPnz52O1Whk+fDidOnVi8uTJTJs2jWbNmvH444/TpEkTkpKS+PHHH1mzZg3p6ekMHTqU6OjobFtpXZWamophGDRv3px77rmHoKAgfH19qVKlCmfOnOGXX35h0aJFpKen8/TTT+Pn58d9992XbYz/+7//IyEhgbfffpv9+/cD5DrT8aabbiryz+Kpp55y/MyrVKnCkCFDuOeee/Dw8CAqKoqvv/6aU6dOsWvXLjp37szOnTupU6dOvmM++eST/Pe//6Vly5aEhYU5Pj/Lli1jwYIFALz11lt07tyZu+++u8gxF5XJMEqu9MPMmTN54oknABg2bFiOD2xubr75ZmJiYgD7FM68plte1bVrV3755RcAfv31V+68887rirm0JCUl4e3tTWJiIl5eXs4OR0RERETkhtdz0s8cir+U7VoNDwuRb/fExVzwEqbSUl6/G6SmphITE+NYkpafN+bvITou53Y9lU1zP0/ee/C2Un/OihUr6NGjBxaLJdf7KSkpPPbYY47kR27fjceNG8c777zjOG/WrBnr1q2jfv362drt2bOHe++9l4QEe5J63rx5DB48OFubo0ePZitC6OLiwvfff8+QIUOytbty5QpDhgxh8eLFgH0/9KVLl+aIv1u3btmSaM8//zyffPIJLi4uub7fAQMGOMbp1asX8+fPzzFBZ/PmzfTt29exVHXRokWEhIRka5OSkkK7du34448/APj+++959NFHAbh8+TLBwcEcPHgQgPDwcB5++OFc42ncuDHHjh2jUaNGuVYYvfZnf++997Jo0aIcMY8ZM8axp3zbtm2JjIzk8ccf56uvvsqR3Hv88ceZNWsWAB988AGvvvpqjuceO3aMixcv0rp161zjBvtSzd69exMfH0/Tpk2Jjo7OdYln1t9RYdJGBbVfsGABDz74IAA1atRg1apVtG/fPlub5ORkQkJCHFt4DRw4MNcE37Wfn9GjR/Phhx9iNmffEe399993JE3vu+8+lixZUuD7yE1R/qx0+ky25s2bFynJdrXt1b4iIiIiIiKnL17hePx5HjBvpZfLDrxIIQkP4uv0wMV6N5gL3v9Z8hYdl8zvxy86O4xKo2/fvvne9/DwYObMmfz0009cvnyZb7/9Nt8JKGazmfDw8BwJNoDb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\n",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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geakSZPKPfe7774rct5ZZ51lbty4scS+s2fPNiMiIvx9hw8fXmK/uXPnFhnzpZdeKnMO6enp5htvvGFOmTKlxPaaXKJb2LG+X0VERETk9KMluiIictyeeeYZtm7dCoDNZmPKlCmMHDkSwzCK9a1bty7fffcdLVq0ACA1NZWXX365WL+tW7eyY8cO/+O33nqLqKioUudgs9no27dvkcywmmSaJk6nkx9//JF//OMfJfZ54IEH6NWrl//xxIkTSx3v5ZdfJi0tzf/4iy++oH///iX2veGGG3juuefw+XzHNvlj8P777zN8+PAy+3g8Hm6//Xb/41atWjF//nxatmxZYv9+/frx1Vdf+R9PnjyZtWvXFutXeHlz586d+ec//1nmPCIiIrjzzjsZOnRomf1ERERERGoLBfhEROS45Obm8t577/kfjx49mkGDBpV5TmhoaJFA3Pjx44vtw3b0Xm4FAcHa5JZbbqFz585l9rnpppv8xytWrChx3zyv18unn37qf3zhhRdyySWXlDnuvffeS7NmzSo542PTtWtXRo4cWW6/KVOmsGvXLv/jd999l4iIiDLPufDCC7n00kv9jwu/1woUfq/UxveJiIiIiMjxUoBPRESOy08//URKSor/8T333FOh8wYPHuwP7iQnJ7Ny5coi7SEhIUUeL1y48DhnWv1GjRpVbp9zzjnHf5yfn8/27duL9Vm1alWRINaYMWPKHdfhcHDttddWaJ7HqyLBPYBJkyb5jzt16lQke7Gi48+ZM6dYe+H3ytKlS0st2iEiIiIicqpSgE9ERI5L4Uqk9erVo2PHjhU6z263F8luW7JkSZH21q1bExQU5H88evRo5s6de5yzrT5Op5Ozzjqr3H4NGjQo8rjwMtwCS5cuLfL4/PPPr9AcKtrvePXo0aNC/f744w//8cCBAys8frdu3fzH69evJysrq0h74dd5y5YtXHvttezdu7fC44uIiIiI1HYK8ImIyHEpnHnXpk2bSp0bHx/vP969e3eRtqCgoCIZcLt27aJfv360bt2aBx98kFmzZhWp2HuyiYmJqVB109DQ0CKPs7Ozi/UpXB02PDychg0bVmgOlf15HKuCqq9l2bdvHwcOHPA/rszcCr9PfD4f+/btK9I+bNgwYmNj/Y+/+uormjRpwsCBA3n11VdZsWJFte5HKCIiIiJS3RTgExGR43Lo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Ozub7Oxs/+N69erx9ddf07p16yLnR0REVNtcy/LYY49Rv3597rrrLvLz8wFYvHhxuZl8UP57JSMjgx9++KFIRmdJbr/9dh599NFS24cOHcptt93GuHHjAMjPz+fjjz8u9n42DIMnnniCUaNGVXmAr7a/X0VERESk+miJroiIVJmWLVuyatUq3n777SKFCkridDo577zzePnll0usQDpgwACeeeYZevbsSUBAQJljNWjQgCeffJIVK1bQuHHjMvveeuutLF26lLFjx9KpUyeioqJOisy2imrcuDG//fYbEydO5JJLLiEhIYGAgADq1avHueeey8svv8zatWvp2bNnkWw1sDItTxY333wzmzZt4pZbbil3XnXq1OGaa67h22+/5eGHHy7W/t///pfbb7+dZs2alXvdnj17MnPmTN5+++1yl9W+/fbbvPLKK0Wq6hbWtm1bZsyYwWOPPVbudY9VbX+/ioiIiEj1MEzTNGt6EiIicmravn07ixcv5sCBA6SlpRESEkJsbCytWrWiffv2hIaGVmicvLw8Vq5cyebNm0lKSiI3N5fg4GDq1q1Lx44dOfPMMxX0KMHs2bO54IILAGvJbmZmJk6ns4ZnVZzH42HJkiVs3LiR5ORkXC4X4eHhJCQk0LZtW1q2bFnhPe6SkpJYvXo127ZtIzU1FY/HQ0REBI0bN6Zr167HtJQ1Pz+fX375hY0bN5KVlUX9+vVp164dXbt2rfRYIiIiIiInggJ8IiIip6j777+fl156CYCzzz6bJUuW1PCMRERERETkRNASXRERkVPQwYMHi+wXV7gCr4iIiIiInFoU4BMREaklUlNT2bRpU7n9srKyuPrqq0lJSQGsQhDXX3/9iZ6eiIiIiIjUEAX4REREaon9+/fTtm1brrjiCqZOnVqsmmpycjKffPIJnTt3Zu7cuf7n77jjDpo3b17d0xURERERkWqiPfhERERqiQ0bNtCmTZsiz0VHRxMREUFmZiapqakc/c/6Oeecw5w5cypc0ERERERERGofZfCJiIjUEg6Ho1g12dTUVHbs2EFKSkqR4J7NZmP06NHMnTtXwT0RERERkVOcMvhOQT6fj7179xIeHl7sg6CIiNRuu3fvZubMmfzxxx9s3LiRvXv3kpWVhd1uJyYmhiZNmnDeeedxxRVX0Lp165qeroiI1DDTNMnMzKRBgwbYbCd/fodpmrjdbnw+X01PRUSkRthsNpxOZ6XjOQrwnYJ2795No0aNanoaIiIiIiJykti1axcJCQk1PY1S5eTkkJ6eTmZmJl6vt6anIyJSo+x2O+Hh4URGRhISElKhcxwneE5SA8LDwwHrH/GIiIgano2IiIiIiNSUjIwMGjVq5P+McDLKzMxk9+7dOJ1OoqKiCA0NxWazaTWSiJx2TNPE5/ORnZ1NRkYGaWlpJCQkVOh3uAJ8p6CCfwgjIiIU4BMRERERkZM2WJaTk8Pu3buJiIigQYMGJ+08RUSqU2hoKHXr1mXv3r3s3r2bJk2alJvJd/JvwiAiIiIiIiKnpPT0dJxOp4J7IiJHMQyDBg0a4HQ6SU9PL7e/AnwiIiIiIiJS7QoKgERERCi4JyJSAsMwiIiIIDMzk/JKaCjAJyIiIiIiItXO7Xbj9XoJDQ2t6amIiJy0QkJC8Hq9uN3uMvspwCciIiIiIiLVzufzAWCz6WOpiEhp7HY7cOR3Zmn0m1RERERERERqjJbnioiUrqK/IxXgExERERERERERqcUU4BMREREREREREanFFOATERERERERERGpxRTgExERERERERERqcUU4BMREREREREREanFFOATEREREREREaklmjZtimEYNG3atKanctLo3bs3hmGc1lW5HTU9ARERERERERERkQLjx49n+/btADzxxBM1OpfaQgE+ERERERERERE5aYwfP55ffvkFUICvohTgExERERERERGpJQoy2+SI+fPn1/QUapz24BMREREREREREanFFOATERERERERERGpxbREV06IlduS2Dz/M9qk/0aIJ50AXy6GaeI08wj0ZIMBhgH59lB89mBMwOnLJ8CbhdseiscejGGA05uHw52JYdgAE48zDO/hNntBGwYYJl5nOD5HMAZg8+Zhd2WCYWBgteEMAUxs3jxs+Rlg2DAwMQPCMZ0hGIDhzcXIz4RAq7+BCZ48jLx0a8ImEBQOjhAwAHcunIi2/AxrDif6Oifr/Gw2CAiF4GhofQm0HQLOoGp454qIiIiISF5eHrNmzWLOnDn89ddf/P3336SlpREUFES9evXo3r07o0aN4oILLih1jCeeeIInn3wSgHnz5tG7d2/mzp3LuHHjWLRoEfv37ycqKoouXbpw0003cfnll5c61vbt20lMTARg9OjRjB8/nj179vDmm28y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5pn+8++8804++ugjPB4Pb775JsuWLeOKK66gYcOG7N+/n+nTpzNnzhzCwsK47LLLmDJlSrXclxwbBfhERERECrQbDPaJMPUWyEuzCnBkJREeeJBunnQ8difbvfH0sq+mn20pOQQzx9f5SAEOXyIOm0HduGbUydmmAhwiInLaiomJYdKkSQwePJjs7GyWLFnCkiVLivQ588wz+fbbb7n++utraJble/fdd2nZsiWPPfYYOTk5/Prrr/z666+l9q9Tp84xVbQ9FoGBgcyePZtbb72VCRMm4PF4+Oqrr/jqq69K7G+zFV3E2b59e959911uvfVWPB4Pf/zxB3/88UeRPjExMXzxxRf8+eefCvCd5LREV0RERKSw1hfB/9sM3ceC1209d3jZrsMZQFPbfro5/uZj7yDCjVxe9gzzF+B40H0TbdhK0K7fVYBDREROe/369WP16tXceuutNGvWjMDAQKKioujWrRuvvPIKS5YsITExsaanWa5//etf7Nixg+eff54LLriABg0aEBgYSGBgIPHx8fTs2ZN7772X77//nr1791KnTp1qm1twcDCffvopy5Yt46677uLMM88kKioKu91OZGQknTp14tZbb+XHH3/kuuuuK3b+DTfcwKJFi7j22mtJSEjA6XQSExNDp06d+M9//sPq1asZMGBAtd2PHDvDNE2zpichVSsjI4PIyEjS09OJiIio6emIiIjUXu48mPMULHwLMKxsvKjG5N30K1vfHYEnZQcGJu1t2/m3awxX2H+jk20Lc3xnEWekkh3UgMa3fEHDL/pBbgrkplrjnjMW+j+uPZxE5IQ7mT8b5OXlsW3bNhITE6st40lEpLap6O9KZfCJiIiIlMYZBAOfgasnWvvqeV1waDNBE4fRNncZHWzbaGXbzXZfPH3sK+lk28IKsznPea6hg207a7IjCXmzPaRsAZ8XgmOsffkWvQ2vtIWNP9T0HYqIiIjIKUABPhEREZHyFCzb7XaL9Xjnn+DOhYAwHAHBNLXt5xzbegwD7nffxgOOyf4CHEu8LVnla8qW0E6Y0YkQEGqN4fNY+/KtnVZjtyUiIiIipwYF+EREREQqwhkEF70AV34KGOAMBlcWNkcQZmwLUuK6s8aXyIOOSfSzLcUA5vg68z/PcDrYthN/aDHG3qX4DBsEx4JhR/vyiYiIiEhVUIBPREREpDLaDYar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P5677rqLHj16EBIS4i8oMWbMmGMad/r06VxxxRU0adKEoKAg4uLi6NGjB//73/9IT0+v2puopEWLFrFhwwZCQkK48sorS+03depU7r77bm677TaefvppFi9eXI2zFBERkVrLGQSD34K8DCtYd+69RNRLJCnyLDaajbnO/nORyrr35t2MLTcF74XPwJ1LreW9C99SZV0RERGRWqral+heddVVTJ06tcrGy8zMZMSIEXz33XdFnj948CAHDx5k4cKFvPHGG0yePJlzzz23yq5bGZ9++ikAQ4cOJTw8vNR+b7zxRpHHjz76KBdddBETJkwgJibmhM5RREREarlWg+DK8fDVGPh8KARGEB8Yzi/RT9Mkd61/qe5cXxfGOV/hkBnGHyt3cumm78GwH6mse99aCI6q4ZsRERERkcqokQy+wmJiYjjjjDOOaSyPx8OwYcP8wb34+HgeffRRvvjiC95880169uwJwO7du7n44otZu3bt8U3+GLhcLiZNmgSUvjy3U6dOvP3222zYsIHs7Gy2b9/O+PHjadCgATNnzuTSSy/F5/NV57RFRESkNmo3BK78BDDAk4+Rl06jKCdgLdXdajZknPMV+tmWEoCXS7c/w6EDe62lus7gI5V1N/5Qo7chIiIiIpVT7VV0n3nmGTIzM+nSpQtdunQhMTGR8ePHc/311wNWEGz8+PEVGuudd95h7NixALRt25a5c+cSHx9fpM/999/PSy+9BEDPnj35/fffSxxr1KhRlV4Se/nll/Pss8+W2WfKlClcccUVJCQksGPHDmy2isdU9+zZQ4cOHUhJSWHy5MlcddVVFTpPlbJEREROcxtmWtl4riwIjMRns7M6L46O5gYyzGDCyGO2rzPPekYQ5LDxg/0+uPw9+PMtVdYVOcXos4GIyOmh2pfoPvLII1Uyjtfr5amnjmwGPWHChGLBPYDnn3+eOXPmsGLFChYsWMCsWbMYMGBAsX47d+5k48aNlZrDvn37yu1TsDx35MiRlQruATRs2JDrr7+el156iR9++KHCAT4RERE5zbW+yFpq+0o78ORiC4ygaZNEHt7Si/9n+4LZvs7c5r4PgPd4iWyCCFjzDc7MvaqsKyIiIlIL1doqur/88gtJSUkA9OrVi86dO5fYz263c/fdd/sfT5w4scR+8+fPxzTNSn2Vl2mYnJzMDz9YS1yOtXpuy5Yt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xsnNKwz5dOteSOwC7c6GNbMrjJEkSTrouFfwnXnmmXTr1o3evXvTu3dvOnbsyOTJk7n22msrfa9nn32W+fPnA5CWlsaCBQtISkoqHb/lllu46667ePjhh9m7dy9jx45l8eLFFd7r6quvZtmyZZV6/siRI5k0adIRY7Kzsxk+fDhZWVmMGjWK6667rsz4wYJnUVERd911Fz/72c9Kx26++WYKCgoYP348999/f7lr/93s2bPJysqibdu2XHDBBZX6LJIkSarl8rIhNrQtt2fb5hWGfLY1m/9MaQ1xbUKr/SRJko7guAt899xzT5UkUFxczP333196PmXKlDLFvYMefPBB3n77bVauXMmSJUt44403GDRoULm4zZs3V/p9d9u3bz/i+IEDB7j44otZtWoVF1xwQen22UMduo32hhtuKDd+ww03MH78eDZv3sxXX31Fp06dDvu8g/e/6qqriIg47kWWkiRJqo1i4iE39PNnSnIsjRtFUFBUUiZk1Tf/fPd0znZo1qqmM5QkSXVM2KtHixYtYseOHQAMGDCAXr16VRgXGRnJbbfdVno+derUCuMWLlxIMBis1L/JkycfNr+CggIuvfRS3n33Xfr168esWbPKbM09qEOHDhUeH3TCCSfQunVrgNLPW5GMjAzmzZsHuD1XkiSpXkodBps/gIwviYqMIK1NXLmQVVv3QsZ62PIhpF5U8zlKkqQ6JewFvtdff730eMiQIUeMPXT8YBGsOhUXF3PllVcyb948Tj/9dObOnUuzZs0qjD3jjDNKj/fs2VNuvKSkhL179wIc9h4AL730EoWFhZx99tmkpKR8tw8gSZKk2idtBDRNgPkToKSY09rGlwvZnXOAvHn3huLShtd8jpIkqU4Je4Hvs88+Kz3u27fvEWOTkpJo164dALt27WL37t3VllcwGOS6667j5Zdfplu3brz55ps0b978sPHt2rUrXX24YMGCcuOLFy+moKCApk2bkpqaetj7PP/884Cr9yRJkuqtqBgY/gSsmwfTr6J/871lhjsFtvHHqEeI/urNUFxUTHjylCRJdUbYC3yHvi+vY8eOR40/NKay79qrjPHjx/P888/TqVMn3nrrLVq1Ovq7T376058CofcTfvnll6Vf3759Oz/+8Y8BuP7662ncuHGF13/xxResWLGC6Oho0tPTq+BTSJIkqVZKGQzpL8KW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\n",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## Get pct error from many approximations\n",
    "\n",
    "# Define array of xs to test on\n",
    "xs = np.logspace(-1, 3, 300)\n",
    "\n",
    "# Save errors\n",
    "errors = []\n",
    "num_correct = 0\n",
    "num_examples = 2\n",
    "pct_error_limit = 100\n",
    "\n",
    "# Run through 25 approximations\n",
    "# for _ in range(5):\n",
    "while num_correct < num_examples:\n",
    "\n",
    "  # Generate integral and prompt\n",
    "  bounds, g, f, sign, prompt = generate_problem()\n",
    "\n",
    "  # Generate solution and statement\n",
    "  approximation, statement = get_solution(bounds, g, f, sign) # this is the approximate solution by analytical\n",
    "\n",
    "  # Skip approximations that have f'(t_0) = 0 when t_0 on bounds\n",
    "  if type(approximation) == sp.core.numbers.NaN:\n",
    "    continue\n",
    "\n",
    "  # Skip approximations that have g(t_0) = 0 since we need higher order terms for Laplace\n",
    "  elif approximation == 0:\n",
    "    continue\n",
    "\n",
    "  # Get numerical solution\n",
    "  # this version only returns the ones without an error\n",
    "  numerical_vals, num_vals = integrate_numerically(bounds, g, f, sign, xs, max_error=1000)\n",
    "\n",
    "  # Get analytical approximation\n",
    "  # Computes the approximate value num_vals times; up to the point where the integration error overflows\n",
    "  approx_vals = evaluate_analytical(approximation, xs, max_val=10**90)[:num_vals]\n",
    "\n",
    "  plot_results(approx_vals, numerical_vals, xs)\n",
    "\n",
    "  # Get error\n",
    "  error = get_last_pct_error(approx_vals, numerical_vals)\n",
    "  if error <= pct_error_limit:\n",
    "    num_correct += 1\n",
    "    # Save and print\n",
    "    errors.append(error)\n",
    "    print(error)\n",
    "\n",
    "  else:\n",
    "    print(f\"Error exceeded on this iteration ({error}%). Trying again.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "YOR8QjH8c8Q9"
   },
   "source": [
    "## Dataset generation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "YSUHVFNmdFlX"
   },
   "source": [
    "Here we generate a dataset! Note that it may take some time, as numerically finding the minimum of f(t) can be slow since we have made it robust to rapidly oscillating functions."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Adding the error calculation takes a bit longer."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Try/catch block to avoid errors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 692,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_dataset(n, filename, pct_error_limit):\n",
    "  \"\"\"\n",
    "  This function generates a csv file called filename with n prompts and solutions\n",
    "  and saves it to the specified path.\n",
    "\n",
    "  It excludes any approximations that give zero, as we need higher order terms\n",
    "  to get any information from these integrals using the Laplace method.\n",
    "  \"\"\"\n",
    "  current_path = os.getcwd()\n",
    "\n",
    "  xs = np.logspace(-1, 3, 300)\n",
    "  data = []\n",
    "\n",
    "  num_complete_problems = 0\n",
    "  counter = 0\n",
    "\n",
    "  while num_complete_problems < n:\n",
    "    try:\n",
    "      # Generate integral and prompt\n",
    "      bounds, g, f, sign, prompt = generate_problem()\n",
    "\n",
    "      # Generate solution and statement\n",
    "      approximation, solution_statement = get_solution(bounds, g, f, sign)\n",
    "\n",
    "      # Skip approximations that give zero. Laplace method to first order gives no information\n",
    "      if approximation == 0:\n",
    "        continue\n",
    "\n",
    "      # Skip NaN approximations, which occur when f'(t_0) == 0 for t_0 on the bounds\n",
    "      elif type(approximation) == sp.core.numbers.NaN:\n",
    "        continue\n",
    "\n",
    "      boxed_solution = f\"\\\\boxed{{I(x) \\\\approx {sp.latex(approximation)}}}\"\n",
    "\n",
    "      numerical_vals, num_vals = integrate_numerically(bounds, g, f, sign, xs, max_error=1000)\n",
    "      approx_vals = evaluate_analytical(approximation, xs, max_val=10**90)[:num_vals]\n",
    "\n",
    "      error = get_last_pct_error(approx_vals, numerical_vals)\n",
    "      non_zero_indices = np.nonzero(numerical_vals)\n",
    "      last_non_zero_index = non_zero_indices[0][-1]\n",
    "      large_x_eval_point = xs[last_non_zero_index]\n",
    "      large_x_numerical_eval = numerical_vals[last_non_zero_index]\n",
    "      large_x_approx_eval = approx_vals[last_non_zero_index]\n",
    "      \n",
    "      if error <= pct_error_limit:\n",
    "        data.append([prompt, solution_statement, boxed_solution, large_x_approx_eval, large_x_numerical_eval, large_x_eval_point])\n",
    "        print(f\"{counter+1} complete\")\n",
    "        np.save( 'approx.npy', approx_vals)\n",
    "        np.save( 'numer.npy', numerical_vals)\n",
    "        np.save('xs.npy', xs)\n",
    "        with open('box.txt', 'w') as f:\n",
    "            f.write(boxed_solution)\n",
    "       # plot_results(approx_vals, numerical_vals,xs, boxed_solution)\n",
    "       # plt.show()\n",
    "        num_complete_problems += 1\n",
    "\n",
    "      else:\n",
    "        print(f\"{counter+1} Error exceeded: {error}%\")\n",
    "\n",
    "    except Exception as e:\n",
    "      print(f\"Error in iteration {counter+1}: {e}. Moving to the next iteration.\")\n",
    "      continue  # Continue to the next iteration even if an error occurred\n",
    "    counter += 1\n",
    "\n",
    "  # Convert to array\n",
    "  data = np.array(data)\n",
    "\n",
    "  # Save array as csv file to path\n",
    "  full_path = os.path.join(current_path, filename)  # Combine directory with filename\n",
    "  data_df = pd.DataFrame(data, columns=[\"question\", \"solution\", \"extracted_answer\",\\\n",
    "    \"large_analytical\", \"large_numerical\", \"large_eval_point\"])\n",
    "  data_df.to_csv(full_path, index=False)\n",
    "\n",
    "  return data_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 718,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Ghs4F5yjdImI",
    "outputId": "8dc4d002-d788-4983-b51c-540ead792b71",
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 complete\n",
      "2 complete\n",
      "3 complete\n",
      "4 complete\n",
      "5 complete\n",
      "6 Error exceeded: 173.290908773458%\n",
      "7 Error exceeded: 10.5081690496349%\n",
      "8 complete\n",
      "9 Error exceeded: 36.3687903492252%\n",
      "10 complete\n",
      "11 complete\n",
      "12 complete\n",
      "13 Error exceeded: 8467.55858474949%\n",
      "14 complete\n",
      "15 complete\n",
      "16 Error exceeded: 11.1801105528022%\n",
      "17 complete\n",
      "18 complete\n",
      "19 complete\n",
      "20 complete\n"
     ]
    }
   ],
   "source": [
    "## Generate dataset!\n",
    "\n",
    "# Number of problems\n",
    "n = 15\n",
    "\n",
    "# Generate dataset\n",
    "data = generate_dataset(n=n, filename=\"laplace_integral_data.csv\", pct_error_limit=10)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Post-Processing"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Three post-processing functions are provided. The first function rounds the numerical values in the solutions to the second decimal place. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 719,
   "metadata": {},
   "outputs": [],
   "source": [
    "def round_numbers_in_string(input_string):\n",
    "    # Define a function to round numbers\n",
    "    def round_match(match):\n",
    "        # Original matched string\n",
    "        original_number = match.group(0)\n",
    "        # Convert the matched string to a float and round it\n",
    "        number = float(original_number)\n",
    "        rounded_number = round(number, 2)\n",
    "\n",
    "        # Determine formatting based on original presentation and rounded result\n",
    "        if abs(number - rounded_number) < 0.005 and len(original_number.split('.')[1]) == 1:\n",
    "            # If the original number was close to the rounded result and had only one digit after decimal,\n",
    "            # return the original number to avoid unnecessary '.10' addition\n",
    "            return original_number\n",
    "        else:\n",
    "            # Apply two decimal formatting, automatically includes cases like .101 becoming .10\n",
    "            return f\"{rounded_number:.2f}\"\n",
    "\n",
    "    # Use regex to find all numbers in the string and apply the rounding\n",
    "    rounded_string = re.sub(r\"\\b\\d+\\.\\d+\\b\", round_match, input_string)\n",
    "    return rounded_string\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 720,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(len(data)): \n",
    "    data.loc[i,'solution']=round_numbers_in_string(data.loc[i, 'solution'])\n",
    "    data.loc[i,'extracted_answer']=round_numbers_in_string(data.loc[i, 'extracted_answer'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The second function replaces $--$ with $+$ when it appears in the solution. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 721,
   "metadata": {},
   "outputs": [],
   "source": [
    "def replace_minus_minus_with_plus(math_text):\n",
    "    # Replace all instances of '--' with '+'\n",
    "    updated_text = math_text.replace(\"--\", \"+\")\n",
    "    return updated_text"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 722,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(len(data)): \n",
    "    data.loc[i,'solution']=replace_minus_minus_with_plus(data.loc[i, 'solution'])\n",
    "    data.loc[i,'extracted_answer']=replace_minus_minus_with_plus(data.loc[i, 'extracted_answer'])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The third function identifies solutions with a particular string. To solve randomly generated Laplace integral problems, the \"get_solution\" function considers a number of different cases (through a series of if/else statements), each of which require slightly different treatments in their solutions. Because problems are randomly generated, some cases are more/less likely to be generated. To weight certain cases more or less in the training/evaluation dataset, one can generate extra data, identify the cases based on text used in the solution for each case with this function, and weight the final dataset accordingly."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 723,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_entries_with_string(df, search_string):\n",
    "    # Use applymap to apply str.contains to each element; this returns a DataFrame of booleans\n",
    "    mask = df.applymap(lambda x: search_string in str(x) if pd.notna(x) else False)\n",
    "    # Filter the DataFrame to keep only the rows where any column matches the condition\n",
    "    filtered_df = df[mask.any(axis=1)]\n",
    "    return filtered_df"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "As an example, to find problems/solutions where the critical point is found numerically, we use the search string \"annealing.\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 724,
   "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>question</th>\n",
       "      <th>solution</th>\n",
       "      <th>extracted_answer</th>\n",
       "      <th>large_analytical</th>\n",
       "      <th>large_numerical</th>\n",
       "      <th>large_eval_point</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - 0.31 \\sqrt{\\pi} \\sqrt{\\f...</td>\n",
       "      <td>-3089126206065.59</td>\n",
       "      <td>-3079597825773.524414</td>\n",
       "      <td>162.443501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{4.28 e^{- 0.10 x}}...</td>\n",
       "      <td>-3.64253315365385e-46</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.71 e^{- 0.04 x}}{x}}</td>\n",
       "      <td>4.37361660799908e-22</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.10 e^{- 0.48 x}}...</td>\n",
       "      <td>-2.33206174520629e-213</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{2.25 e^{2.61 x}}{x}}</td>\n",
       "      <td>-2.74924336423193e+17</td>\n",
       "      <td>-287134096001236832.0</td>\n",
       "      <td>16.119734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.47 e^{1.13 x}}{x}}</td>\n",
       "      <td>-2261725082747.06</td>\n",
       "      <td>-2353071423849.473145</td>\n",
       "      <td>28.942661</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.12 e^{4.14 x}}{x}}</td>\n",
       "      <td>188945529407733.</td>\n",
       "      <td>183381371263017.75</td>\n",
       "      <td>8.977952</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.33 e^{0.63 x}}{x}}</td>\n",
       "      <td>320757309255.174</td>\n",
       "      <td>293885435957.430664</td>\n",
       "      <td>50.389626</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                             question  \\\n",
       "0   Consider the integral \\par \\begin{equation} I(...   \n",
       "2   Consider the integral \\par \\begin{equation} I(...   \n",
       "3   Consider the integral \\par \\begin{equation} I(...   \n",
       "6   Consider the integral \\par \\begin{equation} I(...   \n",
       "9   Consider the integral \\par \\begin{equation} I(...   \n",
       "10  Consider the integral \\par \\begin{equation} I(...   \n",
       "12  Consider the integral \\par \\begin{equation} I(...   \n",
       "13  Consider the integral \\par \\begin{equation} I(...   \n",
       "\n",
       "                                             solution  \\\n",
       "0   The integral is of the form \\begin{equation} I...   \n",
       "2   The integral is of the form \\begin{equation} I...   \n",
       "3   The integral is of the form \\begin{equation} I...   \n",
       "6   The integral is of the form \\begin{equation} I...   \n",
       "9   The integral is of the form \\begin{equation} I...   \n",
       "10  The integral is of the form \\begin{equation} I...   \n",
       "12  The integral is of the form \\begin{equation} I...   \n",
       "13  The integral is of the form \\begin{equation} I...   \n",
       "\n",
       "                                     extracted_answer        large_analytical  \\\n",
       "0   \\boxed{I(x) \\approx - 0.31 \\sqrt{\\pi} \\sqrt{\\f...       -3089126206065.59   \n",
       "2   \\boxed{I(x) \\approx - \\frac{4.28 e^{- 0.10 x}}...   -3.64253315365385e-46   \n",
       "3    \\boxed{I(x) \\approx \\frac{0.71 e^{- 0.04 x}}{x}}    4.37361660799908e-22   \n",
       "6   \\boxed{I(x) \\approx - \\frac{0.10 e^{- 0.48 x}}...  -2.33206174520629e-213   \n",
       "9    \\boxed{I(x) \\approx - \\frac{2.25 e^{2.61 x}}{x}}   -2.74924336423193e+17   \n",
       "10   \\boxed{I(x) \\approx - \\frac{0.47 e^{1.13 x}}{x}}       -2261725082747.06   \n",
       "12     \\boxed{I(x) \\approx \\frac{0.12 e^{4.14 x}}{x}}        188945529407733.   \n",
       "13     \\boxed{I(x) \\approx \\frac{0.33 e^{0.63 x}}{x}}        320757309255.174   \n",
       "\n",
       "         large_numerical large_eval_point  \n",
       "0  -3079597825773.524414       162.443501  \n",
       "2                   -0.0           1000.0  \n",
       "3                    0.0           1000.0  \n",
       "6                   -0.0           1000.0  \n",
       "9  -287134096001236832.0        16.119734  \n",
       "10 -2353071423849.473145        28.942661  \n",
       "12    183381371263017.75         8.977952  \n",
       "13   293885435957.430664        50.389626  "
      ]
     },
     "execution_count": 724,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "find_entries_with_string(data, \"annealing\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The search string \"we can remove this term from the exponent\" can be used to find cases where the maximum/minimum is between the integral bounds not on the bounds."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 725,
   "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>question</th>\n",
       "      <th>solution</th>\n",
       "      <th>extracted_answer</th>\n",
       "      <th>large_analytical</th>\n",
       "      <th>large_numerical</th>\n",
       "      <th>large_eval_point</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - 0.31 \\sqrt{\\pi} \\sqrt{\\f...</td>\n",
       "      <td>-3089126206065.59</td>\n",
       "      <td>-3079597825773.524414</td>\n",
       "      <td>162.443501</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - 0.82 \\sqrt{\\pi} \\sqrt{\\f...</td>\n",
       "      <td>-270745043297.274</td>\n",
       "      <td>-271265539822.99115</td>\n",
       "      <td>28.942661</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx 0.35 \\sqrt{\\pi} \\sqrt{\\fra...</td>\n",
       "      <td>3.09364355877521e-315</td>\n",
       "      <td>0.0</td>\n",
       "      <td>350.873446</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                             question  \\\n",
       "0   Consider the integral \\par \\begin{equation} I(...   \n",
       "5   Consider the integral \\par \\begin{equation} I(...   \n",
       "14  Consider the integral \\par \\begin{equation} I(...   \n",
       "\n",
       "                                             solution  \\\n",
       "0   The integral is of the form \\begin{equation} I...   \n",
       "5   The integral is of the form \\begin{equation} I...   \n",
       "14  The integral is of the form \\begin{equation} I...   \n",
       "\n",
       "                                     extracted_answer       large_analytical  \\\n",
       "0   \\boxed{I(x) \\approx - 0.31 \\sqrt{\\pi} \\sqrt{\\f...      -3089126206065.59   \n",
       "5   \\boxed{I(x) \\approx - 0.82 \\sqrt{\\pi} \\sqrt{\\f...      -270745043297.274   \n",
       "14  \\boxed{I(x) \\approx 0.35 \\sqrt{\\pi} \\sqrt{\\fra...  3.09364355877521e-315   \n",
       "\n",
       "         large_numerical large_eval_point  \n",
       "0  -3079597825773.524414       162.443501  \n",
       "5    -271265539822.99115        28.942661  \n",
       "14                   0.0       350.873446  "
      ]
     },
     "execution_count": 725,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "find_entries_with_string(data, \"we can remove this term from the exponent\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The search string \"upper bound\" or \"lower bound\" can be used to find cases where the maximum and minimum are on the upper or lower bound"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 726,
   "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>question</th>\n",
       "      <th>solution</th>\n",
       "      <th>extracted_answer</th>\n",
       "      <th>large_analytical</th>\n",
       "      <th>large_numerical</th>\n",
       "      <th>large_eval_point</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.15 e^{1.82 x}}{x}}</td>\n",
       "      <td>-305066448017.368</td>\n",
       "      <td>-310674672788.664368</td>\n",
       "      <td>17.144061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.71 e^{- 0.04 x}}{x}}</td>\n",
       "      <td>4.37361660799908e-22</td>\n",
       "      <td>0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.20 e^{1.0 x}}{x}}</td>\n",
       "      <td>-22229809347785.1</td>\n",
       "      <td>-20513735545384.023438</td>\n",
       "      <td>35.907399</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{6.81 e^{- 0.06 x}}...</td>\n",
       "      <td>-6.56947901117154e-28</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.43 e^{- 0.62 x}}...</td>\n",
       "      <td>-1.31000815638595e-273</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.47 e^{1.13 x}}{x}}</td>\n",
       "      <td>-2261725082747.06</td>\n",
       "      <td>-2353071423849.473145</td>\n",
       "      <td>28.942661</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.08 e^{3.31 x}}{x}}</td>\n",
       "      <td>433380295794.756</td>\n",
       "      <td>417934336246.304565</td>\n",
       "      <td>9.548455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.33 e^{0.63 x}}{x}}</td>\n",
       "      <td>320757309255.174</td>\n",
       "      <td>293885435957.430664</td>\n",
       "      <td>50.389626</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                             question  \\\n",
       "1   Consider the integral \\par \\begin{equation} I(...   \n",
       "3   Consider the integral \\par \\begin{equation} I(...   \n",
       "4   Consider the integral \\par \\begin{equation} I(...   \n",
       "7   Consider the integral \\par \\begin{equation} I(...   \n",
       "8   Consider the integral \\par \\begin{equation} I(...   \n",
       "10  Consider the integral \\par \\begin{equation} I(...   \n",
       "11  Consider the integral \\par \\begin{equation} I(...   \n",
       "13  Consider the integral \\par \\begin{equation} I(...   \n",
       "\n",
       "                                             solution  \\\n",
       "1   The integral is of the form \\begin{equation} I...   \n",
       "3   The integral is of the form \\begin{equation} I...   \n",
       "4   The integral is of the form \\begin{equation} I...   \n",
       "7   The integral is of the form \\begin{equation} I...   \n",
       "8   The integral is of the form \\begin{equation} I...   \n",
       "10  The integral is of the form \\begin{equation} I...   \n",
       "11  The integral is of the form \\begin{equation} I...   \n",
       "13  The integral is of the form \\begin{equation} I...   \n",
       "\n",
       "                                     extracted_answer        large_analytical  \\\n",
       "1    \\boxed{I(x) \\approx - \\frac{0.15 e^{1.82 x}}{x}}       -305066448017.368   \n",
       "3    \\boxed{I(x) \\approx \\frac{0.71 e^{- 0.04 x}}{x}}    4.37361660799908e-22   \n",
       "4     \\boxed{I(x) \\approx - \\frac{0.20 e^{1.0 x}}{x}}       -22229809347785.1   \n",
       "7   \\boxed{I(x) \\approx - \\frac{6.81 e^{- 0.06 x}}...   -6.56947901117154e-28   \n",
       "8   \\boxed{I(x) \\approx - \\frac{0.43 e^{- 0.62 x}}...  -1.31000815638595e-273   \n",
       "10   \\boxed{I(x) \\approx - \\frac{0.47 e^{1.13 x}}{x}}       -2261725082747.06   \n",
       "11     \\boxed{I(x) \\approx \\frac{0.08 e^{3.31 x}}{x}}        433380295794.756   \n",
       "13     \\boxed{I(x) \\approx \\frac{0.33 e^{0.63 x}}{x}}        320757309255.174   \n",
       "\n",
       "          large_numerical large_eval_point  \n",
       "1    -310674672788.664368        17.144061  \n",
       "3                     0.0           1000.0  \n",
       "4  -20513735545384.023438        35.907399  \n",
       "7                    -0.0           1000.0  \n",
       "8                    -0.0           1000.0  \n",
       "10  -2353071423849.473145        28.942661  \n",
       "11    417934336246.304565         9.548455  \n",
       "13    293885435957.430664        50.389626  "
      ]
     },
     "execution_count": 726,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "find_entries_with_string(data, \"upper bound\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 727,
   "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>question</th>\n",
       "      <th>solution</th>\n",
       "      <th>extracted_answer</th>\n",
       "      <th>large_analytical</th>\n",
       "      <th>large_numerical</th>\n",
       "      <th>large_eval_point</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.15 e^{1.82 x}}{x}}</td>\n",
       "      <td>-305066448017.368</td>\n",
       "      <td>-310674672788.664368</td>\n",
       "      <td>17.144061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{4.28 e^{- 0.10 x}}...</td>\n",
       "      <td>-3.64253315365385e-46</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.20 e^{1.0 x}}{x}}</td>\n",
       "      <td>-22229809347785.1</td>\n",
       "      <td>-20513735545384.023438</td>\n",
       "      <td>35.907399</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{0.10 e^{- 0.48 x}}...</td>\n",
       "      <td>-2.33206174520629e-213</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{6.81 e^{- 0.06 x}}...</td>\n",
       "      <td>-6.56947901117154e-28</td>\n",
       "      <td>-0.0</td>\n",
       "      <td>1000.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx - \\frac{2.25 e^{2.61 x}}{x}}</td>\n",
       "      <td>-2.74924336423193e+17</td>\n",
       "      <td>-287134096001236832.0</td>\n",
       "      <td>16.119734</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.08 e^{3.31 x}}{x}}</td>\n",
       "      <td>433380295794.756</td>\n",
       "      <td>417934336246.304565</td>\n",
       "      <td>9.548455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Consider the integral \\par \\begin{equation} I(...</td>\n",
       "      <td>The integral is of the form \\begin{equation} I...</td>\n",
       "      <td>\\boxed{I(x) \\approx \\frac{0.12 e^{4.14 x}}{x}}</td>\n",
       "      <td>188945529407733.</td>\n",
       "      <td>183381371263017.75</td>\n",
       "      <td>8.977952</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                             question  \\\n",
       "1   Consider the integral \\par \\begin{equation} I(...   \n",
       "2   Consider the integral \\par \\begin{equation} I(...   \n",
       "4   Consider the integral \\par \\begin{equation} I(...   \n",
       "6   Consider the integral \\par \\begin{equation} I(...   \n",
       "7   Consider the integral \\par \\begin{equation} I(...   \n",
       "9   Consider the integral \\par \\begin{equation} I(...   \n",
       "11  Consider the integral \\par \\begin{equation} I(...   \n",
       "12  Consider the integral \\par \\begin{equation} I(...   \n",
       "\n",
       "                                             solution  \\\n",
       "1   The integral is of the form \\begin{equation} I...   \n",
       "2   The integral is of the form \\begin{equation} I...   \n",
       "4   The integral is of the form \\begin{equation} I...   \n",
       "6   The integral is of the form \\begin{equation} I...   \n",
       "7   The integral is of the form \\begin{equation} I...   \n",
       "9   The integral is of the form \\begin{equation} I...   \n",
       "11  The integral is of the form \\begin{equation} I...   \n",
       "12  The integral is of the form \\begin{equation} I...   \n",
       "\n",
       "                                     extracted_answer        large_analytical  \\\n",
       "1    \\boxed{I(x) \\approx - \\frac{0.15 e^{1.82 x}}{x}}       -305066448017.368   \n",
       "2   \\boxed{I(x) \\approx - \\frac{4.28 e^{- 0.10 x}}...   -3.64253315365385e-46   \n",
       "4     \\boxed{I(x) \\approx - \\frac{0.20 e^{1.0 x}}{x}}       -22229809347785.1   \n",
       "6   \\boxed{I(x) \\approx - \\frac{0.10 e^{- 0.48 x}}...  -2.33206174520629e-213   \n",
       "7   \\boxed{I(x) \\approx - \\frac{6.81 e^{- 0.06 x}}...   -6.56947901117154e-28   \n",
       "9    \\boxed{I(x) \\approx - \\frac{2.25 e^{2.61 x}}{x}}   -2.74924336423193e+17   \n",
       "11     \\boxed{I(x) \\approx \\frac{0.08 e^{3.31 x}}{x}}        433380295794.756   \n",
       "12     \\boxed{I(x) \\approx \\frac{0.12 e^{4.14 x}}{x}}        188945529407733.   \n",
       "\n",
       "          large_numerical large_eval_point  \n",
       "1    -310674672788.664368        17.144061  \n",
       "2                    -0.0           1000.0  \n",
       "4  -20513735545384.023438        35.907399  \n",
       "6                    -0.0           1000.0  \n",
       "7                    -0.0           1000.0  \n",
       "9   -287134096001236832.0        16.119734  \n",
       "11    417934336246.304565         9.548455  \n",
       "12     183381371263017.75         8.977952  "
      ]
     },
     "execution_count": 727,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "find_entries_with_string(data, \"lower bound\")"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [
    "W6SwUsIwbPIo",
    "VkhDzEcYiQsL",
    "129KnpFdulQJ",
    "twpudsSLk2LD",
    "irKWcU1y-atO",
    "cnxkYqjF_cAX",
    "yBe2mfyMc6hj"
   ],
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
