{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sympy.integrals.manualintegrate import integral_steps, manualintegrate\n",
    "import sympy as sp\n",
    "x = sp.Symbol('x')\n",
    "f = x/((x + 3)*sp.log(4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{x - 3 \\log{\\left(x + 3 \\right)}}{\\log{\\left(4 \\right)}}$"
      ],
      "text/plain": [
       "(x - 3*log(x + 3))/log(4)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "sp.integrate(f, x, manual = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10000"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import cloudpickle as pickle\n",
    "\n",
    "DATASET = 'prim_bwd'\n",
    "path = f'steps_dataset/{DATASET}/ids/ids.pkl'\n",
    "\n",
    "with open(path, 'rb') as f:\n",
    "    ids = pickle.load(f)\n",
    "\n",
    "ids"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sympy.integrals.manualintegrate import integral_steps, rewrites_rule, manualintegrate\n",
    "import sympy as sp\n",
    "from sympy.core.symbol import Wild\n",
    "from decompose_steps import decompose_steps, steps_to_string\n",
    "from process_action import replace_subexpr, apply_step\n",
    "from expression_tokenizer import ExpressionTokenizer\n",
    "#import logging\n",
    "import time\n",
    "\n",
    "#date_time_idx = time.strftime(\"%Y%m%d-%H%M%S\")\n",
    "#logging.basicConfig(filename = f'dsetlogs/logs_{date_time_idx}.txt', filemode='w', level=logging.INFO)\n",
    "#logging.info(f\"Started logging at {date_time_idx}\")\n",
    "e = ExpressionTokenizer()\n",
    "\n",
    "import os, io\n",
    "def get_steps(data_path: str):\n",
    "\n",
    "    with io.open(data_path, mode='r', encoding='utf-8') as f:\n",
    "        lines = [line.split('\\t\\t') for line in f]\n",
    "    \n",
    "    return lines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\int \\frac{\\cos{\\left(x \\right)}}{\\sqrt{\\sin^{2}{\\left(x \\right)} + 1}}\\, dx$"
      ],
      "text/plain": [
       "Integral(cos(x)/sqrt(sin(x)**2 + 1), x)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "# cos(2x)/(sqrt(1+sin^2(2x)))\n",
    "expr = sp.cos(x)/(sp.sqrt(1+sp.sin(x)**2))\n",
    "sp.integrate(expr, x, manual = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\log{\\left(x \\right)} + \\log{\\left(\\sin{\\left(3 \\right)} \\cos{\\left(\\cos{\\left(3 \\right)} \\right)} + \\sin{\\left(\\cos{\\left(3 \\right)} \\right)} \\cos{\\left(3 \\right)} \\right)} + \\log{\\left(3 \\right)}$"
      ],
      "text/plain": [
       "log(x) + log(sin(3)*cos(cos(3)) + sin(cos(3))*cos(3)) + log(3)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the the current cell or a previous cell. Please review the code in the cell(s) to identify a possible cause of the failure. Click <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. View Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "from sympy import *\n",
    "x = sp.Symbol('x')\n",
    "f = log(3*x*sin(cos(3) + 3))\n",
    "f.expand(trig = True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'* / INT+ 1 INT+ 2 * + * INT- 1 Integral cos x x * INT+ 2 * x cos x atanh INT+ 4'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "y = sp.Symbol('y')\n",
    "' '.join(e.sp_to_seq( (2*x*cos(x) - Integral(cos(x), x))*atanh(4)/2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{\\left(- 2 x \\sin{\\left(x \\right)} + \\cos{\\left(x \\right)}\\right) \\operatorname{atanh}{\\left(4 \\right)}}{2}$"
      ],
      "text/plain": [
       "(-2*x*sin(x) + cos(x))*atanh(4)/2"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "expr = e.seq_to_sp('Integral * * INT+ 1 ^ INT+ 2 INT- 1 * + * INT- 2 * x sin x cos x atanh INT+ 4 x'.split()).args[0]\n",
    "expr "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ConstantTimesRule(integrand=(-2*x*sin(x) + cos(x))*atanh(4)/2, variable=x, constant=atanh(4)/2, other=-2*x*sin(x) + cos(x), substep=AddRule(integrand=-2*x*sin(x) + cos(x), variable=x, substeps=[ConstantTimesRule(integrand=-2*x*sin(x), variable=x, constant=-2, other=x*sin(x), substep=PartsRule(integrand=x*sin(x), variable=x, u=x, dv=sin(x), v_step=SinRule(integrand=sin(x), variable=x), second_step=ConstantTimesRule(integrand=-cos(x), variable=x, constant=-1, other=cos(x), substep=CosRule(integrand=cos(x), variable=x)))), CosRule(integrand=cos(x), variable=x)]))"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integral_steps(expr,x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integral((-2*x*sin(x) + cos(x))*atanh(4)/2, x) -> atanh(4)*Integral(-2*x*sin(x) + cos(x), x)/2 using ('ConstantTimesRule',) at Integral((-2*x*sin(x) + cos(x))*atanh(4)/2, x)\n",
      "atanh(4)*Integral(-2*x*sin(x) + cos(x), x)/2 -> (Integral(-2*x*sin(x), x) + Integral(cos(x), x))*atanh(4)/2 using ('AddRule',) at Integral(-2*x*sin(x) + cos(x), x)\n",
      "(Integral(-2*x*sin(x), x) + Integral(cos(x), x))*atanh(4)/2 -> (-2*Integral(x*sin(x), x) + Integral(cos(x), x))*atanh(4)/2 using ('ConstantTimesRule',) at Integral(-2*x*sin(x), x)\n",
      "(-2*Integral(x*sin(x), x) + Integral(cos(x), x))*atanh(4)/2 -> (-2*x*Integral(sin(x), x) + Integral(cos(x), x) + 2*Integral(sin(x), x, x))*atanh(4)/2 using ('PartsRule', x, sin(x)) at Integral(x*sin(x), x)\n",
      "(-2*x*Integral(sin(x), x) + Integral(cos(x), x) + 2*Integral(sin(x), x, x))*atanh(4)/2 -> (2*x*cos(x) + 2*Integral(-cos(x), x) + Integral(cos(x), x))*atanh(4)/2 using ('SinRule',) at Integral(sin(x), x)\n",
      "(2*x*cos(x) + 2*Integral(-cos(x), x) + Integral(cos(x), x))*atanh(4)/2 -> (2*x*cos(x) - Integral(cos(x), x))*atanh(4)/2 using ('ConstantTimesRule',) at Integral(-cos(x), x)\n",
      "(2*x*cos(x) - Integral(cos(x), x))*atanh(4)/2 -> (2*x*cos(x) - 2*sin(x) + Integral(cos(x), x))*atanh(4)/2 using ('CosRule',) at Integral(cos(x), x)\n",
      "(2*x*cos(x) - 2*sin(x) + Integral(cos(x), x))*atanh(4)/2 -> (2*x*cos(x) - sin(x))*atanh(4)/2 using ('CosRule',) at Integral(cos(x), x)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(steps_to_string(decompose_steps(expr, x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "AddRule(integrand=x*cos(x) + sin(x), variable=x, substeps=[PartsRule(integrand=x*cos(x), variable=x, u=x, dv=cos(x), v_step=CosRule(integrand=cos(x), variable=x), second_step=SinRule(integrand=sin(x), variable=x)), SinRule(integrand=sin(x), variable=x)])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integral_steps(x*cos(x) + sin(x), x)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integral(x*cos(x) + sin(x), x) -> Integral(x*cos(x), x) + Integral(sin(x), x) using ('AddRule',) at Integral(x*cos(x) + sin(x), x)\n",
      "Integral(x*cos(x), x) + Integral(sin(x), x) -> x*Integral(cos(x), x) + Integral(sin(x), x) - Integral(cos(x), x, x) using ('PartsRule', x, cos(x)) at Integral(x*cos(x), x)\n",
      "x*Integral(cos(x), x) + Integral(sin(x), x) - Integral(cos(x), x, x) -> x*sin(x) using ('CosRule',) at Integral(cos(x), x)\n",
      "x*sin(x) -> x*sin(x) + cos(x) + Integral(sin(x), x) using ('SinRule',) at Integral(sin(x), x)\n",
      "x*sin(x) + cos(x) + Integral(sin(x), x) -> x*sin(x) using ('SinRule',) at Integral(sin(x), x)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(steps_to_string(decompose_steps(expr, x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integral((3/2 - x**2)*exp(-x), x) -> (3/2 - x**2)*Integral(exp(-x), x) - Integral(-2*x*Integral(exp(-x), x), x) using ('PartsRule', 3/2 - x**2, exp(-x)) at Integral((3/2 - x**2)*exp(-x), x)\n",
      "(3/2 - x**2)*Integral(exp(-x), x) - Integral(-2*x*Integral(exp(-x), x), x) -> (3/2 - x**2)*Integral(-exp(y), y) - Integral(-2*x*Integral(-exp(y), y), x) using ('URule', y, -x) at Integral(exp(-x), x)\n",
      "(3/2 - x**2)*Integral(-exp(y), y) - Integral(-2*x*Integral(-exp(y), y), x) -> -(3/2 - x**2)*Integral(exp(y), y) - Integral(2*x*Integral(exp(y), y), x) using ('ConstantTimesRule',) at Integral(-exp(y), y)\n",
      "-(3/2 - x**2)*Integral(exp(y), y) - Integral(2*x*Integral(exp(y), y), x) -> -(3/2 - x**2)*exp(y) - Integral(2*x*exp(y), x) using ('ExpRule',) at Integral(exp(y), y)\n",
      "-(3/2 - x**2)*exp(y) - Integral(2*x*exp(y), x) -> -(3/2 - x**2)*exp(-x) - 2*Integral(x*exp(-x), x) using ('ConstantTimesRule',) at Integral(2*x*exp(-x), x)\n",
      "-(3/2 - x**2)*exp(-x) - 2*Integral(x*exp(-x), x) -> -2*x*Integral(exp(-x), x) - (3/2 - x**2)*exp(-x) + 2*Integral(exp(-x), x, x) using ('PartsRule', x, exp(-x)) at Integral(x*exp(-x), x)\n",
      "-2*x*Integral(exp(-x), x) - (3/2 - x**2)*exp(-x) + 2*Integral(exp(-x), x, x) -> -2*x*Integral(-exp(y), y) - (3/2 - x**2)*exp(-x) + 2*Integral(-exp(y), y, x) using ('URule', y, -x) at Integral(exp(-x), x)\n",
      "-2*x*Integral(-exp(y), y) - (3/2 - x**2)*exp(-x) + 2*Integral(-exp(y), y, x) -> 2*x*Integral(exp(y), y) - (3/2 - x**2)*exp(-x) + 2*Integral(-Integral(exp(y), y), x) using ('ConstantTimesRule',) at Integral(-exp(y), y)\n",
      "2*x*Integral(exp(y), y) - (3/2 - x**2)*exp(-x) + 2*Integral(-Integral(exp(y), y), x) -> 2*x*exp(y) - (3/2 - x**2)*exp(-x) + 2*Integral(-exp(y), x) using ('ExpRule',) at Integral(exp(y), y)\n",
      "2*x*exp(y) - (3/2 - x**2)*exp(-x) + 2*Integral(-exp(y), x) -> 2*x*exp(-x) - (3/2 - x**2)*exp(-x) - 2*Integral(exp(-x), x) using ('ConstantTimesRule',) at Integral(-exp(-x), x)\n",
      "2*x*exp(-x) - (3/2 - x**2)*exp(-x) - 2*Integral(exp(-x), x) -> 2*x*exp(-x) - (3/2 - x**2)*exp(-x) - 2*Integral(-exp(y), y) using ('URule', y, -x) at Integral(exp(-x), x)\n",
      "2*x*exp(-x) - (3/2 - x**2)*exp(-x) - 2*Integral(-exp(y), y) -> 2*x*exp(-x) - (3/2 - x**2)*exp(-x) + 2*Integral(exp(y), y) using ('ConstantTimesRule',) at Integral(-exp(y), y)\n",
      "2*x*exp(-x) - (3/2 - x**2)*exp(-x) + 2*Integral(exp(y), y) -> 2*x*exp(-x) - (3/2 - x**2)*exp(-x) + 2*exp(y) using ('ExpRule',) at Integral(exp(y), y)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "expr = (sp.Rational(3,2) - x**2)*sp.exp(-x)\n",
    "print(steps_to_string(decompose_steps(expr, x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[Integral(-50, x) + Integral(2*tan(2*x), x),\n",
       " Integral(-50, x) + 2*Integral(tan(2*x), x)]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "expr = sp.Integral(-50, x) + sp.Integral(2*sp.tan(2*x), x)\n",
    "subexpr = sp.Integral(2*sp.tan(2*x), x)\n",
    "rule = ('ConstantTimesRule',)\n",
    "apply_step((expr, subexpr, rule))[1]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PartsRule(integrand=x*atan(x*acos(5)**3), variable=x, u=atan(x*acos(5)**3), dv=x, v_step=PowerRule(integrand=x, variable=x, base=x, exp=1), second_step=ConstantTimesRule(integrand=x**2*acos(5)**3/(2*(x**2*acos(5)**6 + 1)), variable=x, constant=acos(5)**3/2, other=x**2/(x**2*acos(5)**6 + 1), substep=RewriteRule(integrand=x**2/(x**2*acos(5)**6 + 1), variable=x, rewritten=acos(5)**(-6) - 1/((x**2*acos(5)**6 + 1)*acos(5)**6), substep=AddRule(integrand=acos(5)**(-6) - 1/((x**2*acos(5)**6 + 1)*acos(5)**6), variable=x, substeps=[ConstantRule(integrand=acos(5)**(-6), variable=x), ConstantTimesRule(integrand=-1/((x**2*acos(5)**6 + 1)*acos(5)**6), variable=x, constant=-1/acos(5)**6, other=1/(x**2*acos(5)**6 + 1), substep=ArctanRule(integrand=1/(x**2*acos(5)**6 + 1), variable=x, a=1, b=acos(5)**6, c=1))]))))"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sympy import *\n",
    "x = sp.Symbol('x')\n",
    "y = sp.Symbol('y')\n",
    "f = x*atan(x*acos(5)**3)\n",
    "integral_steps(f, x)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "ename": "PrecisionExhausted",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:499\u001b[0m, in \u001b[0;36mmake_property.<locals>.getit\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    498\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m--> 499\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_assumptions[fact]\n\u001b[1;32m    500\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mKeyError\u001b[39;00m:\n",
      "\u001b[0;31mKeyError\u001b[0m: 'zero'",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:499\u001b[0m, in \u001b[0;36mmake_property.<locals>.getit\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    498\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m--> 499\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_assumptions[fact]\n\u001b[1;32m    500\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mKeyError\u001b[39;00m:\n",
      "\u001b[0;31mKeyError\u001b[0m: 'zero'",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mPrecisionExhausted\u001b[0m                        Traceback (most recent call last)",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:452\u001b[0m, in \u001b[0;36mget_integer_part.<locals>.calc_part\u001b[0;34m(re_im, nexpr)\u001b[0m\n\u001b[1;32m    451\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m--> 452\u001b[0m     check_target(re_im, (x, \u001b[39mNone\u001b[39;49;00m, x_acc, \u001b[39mNone\u001b[39;49;00m), \u001b[39m3\u001b[39;49m)\n\u001b[1;32m    453\u001b[0m \u001b[39mexcept\u001b[39;00m PrecisionExhausted:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:358\u001b[0m, in \u001b[0;36mcheck_target\u001b[0;34m(expr, result, prec)\u001b[0m\n\u001b[1;32m    357\u001b[0m \u001b[39mif\u001b[39;00m a \u001b[39m<\u001b[39m prec:\n\u001b[0;32m--> 358\u001b[0m     \u001b[39mraise\u001b[39;00m PrecisionExhausted(\u001b[39m\"\u001b[39m\u001b[39mFailed to distinguish the expression: \u001b[39m\u001b[39m\\n\u001b[39;00m\u001b[39m\\n\u001b[39;00m\u001b[39m%s\u001b[39;00m\u001b[39m\\n\u001b[39;00m\u001b[39m\\n\u001b[39;00m\u001b[39m\"\u001b[39m\n\u001b[1;32m    359\u001b[0m         \u001b[39m\"\u001b[39m\u001b[39mfrom zero. Try simplifying the input, using chop=True, or providing \u001b[39m\u001b[39m\"\u001b[39m\n\u001b[1;32m    360\u001b[0m         \u001b[39m\"\u001b[39m\u001b[39ma higher maxn for evalf\u001b[39m\u001b[39m\"\u001b[39m \u001b[39m%\u001b[39m (expr))\n",
      "\u001b[0;31mPrecisionExhausted\u001b[0m: Failed to distinguish the expression: \n\n-2 + re(1/2 - 3*I*log((re(acos(5)) + I*im(acos(5)))/sqrt(re(acos(5))**2 + im(acos(5))**2))/pi)\n\nfrom zero. Try simplifying the input, using chop=True, or providing a higher maxn for evalf",
      "\nDuring handling of the above exception, another exception occurred:\n",
      "\u001b[0;31mPrecisionExhausted\u001b[0m                        Traceback (most recent call last)",
      "\u001b[1;32m/home/ubuntu/mert/alpha_integrate/steps.ipynb Cell 12\u001b[0m line \u001b[0;36m1\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B150.136.146.76/home/ubuntu/mert/alpha_integrate/steps.ipynb#X66sdnNjb2RlLXJlbW90ZQ%3D%3D?line=0'>1</a>\u001b[0m decompose_steps(f,x)\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:240\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m    237\u001b[0m         \u001b[39mbreak\u001b[39;00m\n\u001b[1;32m    238\u001b[0m     v \u001b[39m=\u001b[39m v\u001b[39m.\u001b[39msubs(s, func)\n\u001b[0;32m--> 240\u001b[0m decomposed_next_steps \u001b[39m=\u001b[39m decompose_steps(v\u001b[39m*\u001b[39;49mdu, symbol, variable_list)\n\u001b[1;32m    241\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39min\u001b[39;00m decomposed_next_steps:\n\u001b[1;32m    242\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:151\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m    148\u001b[0m \u001b[39mif\u001b[39;00m integrand \u001b[39m!=\u001b[39m substep\u001b[39m.\u001b[39mintegrand:\n\u001b[1;32m    149\u001b[0m     tokenizable_steps\u001b[39m.\u001b[39mappend((old_integral, old_integral, (steps\u001b[39m.\u001b[39m\u001b[39m__class__\u001b[39m\u001b[39m.\u001b[39m\u001b[39m__name__\u001b[39m, ), integral))\n\u001b[0;32m--> 151\u001b[0m decomposed_substep \u001b[39m=\u001b[39m decompose_steps(other, symbol, variable_list, substep)\n\u001b[1;32m    152\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39min\u001b[39;00m decomposed_substep:\n\u001b[1;32m    153\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:527\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m    524\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n\u001b[1;32m    526\u001b[0m substep \u001b[39m=\u001b[39m steps\u001b[39m.\u001b[39msubstep\n\u001b[0;32m--> 527\u001b[0m decomposed_substep \u001b[39m=\u001b[39m decompose_steps(rewritten, symbol, variable_list, substep)\n\u001b[1;32m    528\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39min\u001b[39;00m decomposed_substep:\n\u001b[1;32m    529\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:123\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m    120\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n\u001b[1;32m    122\u001b[0m \u001b[39mfor\u001b[39;00m i, substep \u001b[39min\u001b[39;00m \u001b[39menumerate\u001b[39m(substeps):\n\u001b[0;32m--> 123\u001b[0m     decomposed_substep \u001b[39m=\u001b[39m decompose_steps(integral_terms[i], symbol, variable_list, substep)\n\u001b[1;32m    124\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39min\u001b[39;00m decomposed_substep:\n\u001b[1;32m    125\u001b[0m         \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:151\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m    148\u001b[0m \u001b[39mif\u001b[39;00m integrand \u001b[39m!=\u001b[39m substep\u001b[39m.\u001b[39mintegrand:\n\u001b[1;32m    149\u001b[0m     tokenizable_steps\u001b[39m.\u001b[39mappend((old_integral, old_integral, (steps\u001b[39m.\u001b[39m\u001b[39m__class__\u001b[39m\u001b[39m.\u001b[39m\u001b[39m__name__\u001b[39m, ), integral))\n\u001b[0;32m--> 151\u001b[0m decomposed_substep \u001b[39m=\u001b[39m decompose_steps(other, symbol, variable_list, substep)\n\u001b[1;32m    152\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mNone\u001b[39;00m \u001b[39min\u001b[39;00m decomposed_substep:\n\u001b[1;32m    153\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n",
      "File \u001b[0;32m~/mert/alpha_integrate/decompose_steps.py:98\u001b[0m, in \u001b[0;36mdecompose_steps\u001b[0;34m(expression, symbol, variable_list, steps)\u001b[0m\n\u001b[1;32m     94\u001b[0m     \u001b[39mreturn\u001b[39;00m [\u001b[39mNone\u001b[39;00m]\n\u001b[1;32m     97\u001b[0m \u001b[39melif\u001b[39;00m \u001b[39misinstance\u001b[39m(steps, SIMPLE_STEPS):\n\u001b[0;32m---> 98\u001b[0m     tokenizable_steps\u001b[39m.\u001b[39mappend((integral, integral, (steps\u001b[39m.\u001b[39m\u001b[39m__class__\u001b[39m\u001b[39m.\u001b[39m\u001b[39m__name__\u001b[39m,), steps\u001b[39m.\u001b[39;49meval()))\n\u001b[1;32m    101\u001b[0m \u001b[39melif\u001b[39;00m \u001b[39misinstance\u001b[39m(steps, SPECIAL_SIMPLE_STEPS):\n\u001b[1;32m    102\u001b[0m     tokenizable_steps\u001b[39m.\u001b[39mappend((integral, integral, (steps\u001b[39m.\u001b[39m\u001b[39m__class__\u001b[39m\u001b[39m.\u001b[39m\u001b[39m__name__\u001b[39m,), steps\u001b[39m.\u001b[39meval()))\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/integrals/manualintegrate.py:523\u001b[0m, in \u001b[0;36mArctanRule.eval\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    521\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39meval\u001b[39m(\u001b[39mself\u001b[39m) \u001b[39m-\u001b[39m\u001b[39m>\u001b[39m Expr:\n\u001b[1;32m    522\u001b[0m     a, b, c, x \u001b[39m=\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39ma, \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mb, \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mc, \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mvariable\n\u001b[0;32m--> 523\u001b[0m     \u001b[39mreturn\u001b[39;00m a\u001b[39m/\u001b[39mb \u001b[39m/\u001b[39m sqrt(c\u001b[39m/\u001b[39;49mb) \u001b[39m*\u001b[39m atan(x\u001b[39m/\u001b[39msqrt(c\u001b[39m/\u001b[39mb))\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/functions/elementary/miscellaneous.py:152\u001b[0m, in \u001b[0;36msqrt\u001b[0;34m(arg, evaluate)\u001b[0m\n\u001b[1;32m     68\u001b[0m \u001b[39m\u001b[39m\u001b[39m\"\"\"Returns the principal square root.\u001b[39;00m\n\u001b[1;32m     69\u001b[0m \n\u001b[1;32m     70\u001b[0m \u001b[39mParameters\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    149\u001b[0m \u001b[39m.. [2] https://en.wikipedia.org/wiki/Principal_value\u001b[39;00m\n\u001b[1;32m    150\u001b[0m \u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m    151\u001b[0m \u001b[39m# arg = sympify(arg) is handled by Pow\u001b[39;00m\n\u001b[0;32m--> 152\u001b[0m \u001b[39mreturn\u001b[39;00m Pow(arg, S\u001b[39m.\u001b[39;49mHalf, evaluate\u001b[39m=\u001b[39;49mevaluate)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/cache.py:72\u001b[0m, in \u001b[0;36m__cacheit.<locals>.func_wrapper.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     69\u001b[0m \u001b[39m@wraps\u001b[39m(func)\n\u001b[1;32m     70\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mwrapper\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m     71\u001b[0m     \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 72\u001b[0m         retval \u001b[39m=\u001b[39m cfunc(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m     73\u001b[0m     \u001b[39mexcept\u001b[39;00m \u001b[39mTypeError\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m     74\u001b[0m         \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs \u001b[39mor\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs[\u001b[39m0\u001b[39m]\u001b[39m.\u001b[39mstartswith(\u001b[39m'\u001b[39m\u001b[39munhashable type:\u001b[39m\u001b[39m'\u001b[39m):\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/power.py:371\u001b[0m, in \u001b[0;36mPow.__new__\u001b[0;34m(cls, b, e, evaluate)\u001b[0m\n\u001b[1;32m    367\u001b[0m         \u001b[39mif\u001b[39;00m s\u001b[39m.\u001b[39mis_Number \u001b[39mand\u001b[39;00m s \u001b[39mand\u001b[39;00m den \u001b[39m==\u001b[39m \\\n\u001b[1;32m    368\u001b[0m                 log(\u001b[39m-\u001b[39mfactor_terms(b, sign\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m)) \u001b[39m+\u001b[39m s\u001b[39m*\u001b[39mS\u001b[39m.\u001b[39mImaginaryUnit\u001b[39m*\u001b[39mS\u001b[39m.\u001b[39mPi:\n\u001b[1;32m    369\u001b[0m             \u001b[39mreturn\u001b[39;00m S\u001b[39m.\u001b[39mExp1\u001b[39m*\u001b[39m\u001b[39m*\u001b[39m(c\u001b[39m*\u001b[39mnum)\n\u001b[0;32m--> 371\u001b[0m obj \u001b[39m=\u001b[39m b\u001b[39m.\u001b[39;49m_eval_power(e)\n\u001b[1;32m    372\u001b[0m \u001b[39mif\u001b[39;00m obj \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    373\u001b[0m     \u001b[39mreturn\u001b[39;00m obj\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/power.py:474\u001b[0m, in \u001b[0;36mPow._eval_power\u001b[0;34m(self, other)\u001b[0m\n\u001b[1;32m    472\u001b[0m     s \u001b[39m=\u001b[39m \u001b[39m1\u001b[39m  \u001b[39m# floor = 0\u001b[39;00m\n\u001b[1;32m    473\u001b[0m \u001b[39melif\u001b[39;00m _half(other):\n\u001b[0;32m--> 474\u001b[0m     s \u001b[39m=\u001b[39m exp(\u001b[39m2\u001b[39;49m\u001b[39m*\u001b[39;49mS\u001b[39m.\u001b[39;49mPi\u001b[39m*\u001b[39;49mS\u001b[39m.\u001b[39;49mImaginaryUnit\u001b[39m*\u001b[39;49mother\u001b[39m*\u001b[39;49mfloor(\n\u001b[1;32m    475\u001b[0m         S\u001b[39m.\u001b[39;49mHalf \u001b[39m-\u001b[39;49m e\u001b[39m*\u001b[39;49marg(b)\u001b[39m/\u001b[39;49m(\u001b[39m2\u001b[39;49m\u001b[39m*\u001b[39;49mS\u001b[39m.\u001b[39;49mPi)))\n\u001b[1;32m    476\u001b[0m     \u001b[39mif\u001b[39;00m s\u001b[39m.\u001b[39mis_extended_real \u001b[39mand\u001b[39;00m _n2(sign(s) \u001b[39m-\u001b[39m s) \u001b[39m==\u001b[39m \u001b[39m0\u001b[39m:\n\u001b[1;32m    477\u001b[0m         s \u001b[39m=\u001b[39m sign(s)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/cache.py:72\u001b[0m, in \u001b[0;36m__cacheit.<locals>.func_wrapper.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     69\u001b[0m \u001b[39m@wraps\u001b[39m(func)\n\u001b[1;32m     70\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mwrapper\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m     71\u001b[0m     \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 72\u001b[0m         retval \u001b[39m=\u001b[39m cfunc(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m     73\u001b[0m     \u001b[39mexcept\u001b[39;00m \u001b[39mTypeError\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m     74\u001b[0m         \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs \u001b[39mor\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs[\u001b[39m0\u001b[39m]\u001b[39m.\u001b[39mstartswith(\u001b[39m'\u001b[39m\u001b[39munhashable type:\u001b[39m\u001b[39m'\u001b[39m):\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/function.py:466\u001b[0m, in \u001b[0;36mFunction.__new__\u001b[0;34m(cls, *args, **options)\u001b[0m\n\u001b[1;32m    458\u001b[0m     \u001b[39mraise\u001b[39;00m \u001b[39mTypeError\u001b[39;00m(temp \u001b[39m%\u001b[39m {\n\u001b[1;32m    459\u001b[0m         \u001b[39m'\u001b[39m\u001b[39mname\u001b[39m\u001b[39m'\u001b[39m: \u001b[39mcls\u001b[39m,\n\u001b[1;32m    460\u001b[0m         \u001b[39m'\u001b[39m\u001b[39mqual\u001b[39m\u001b[39m'\u001b[39m: \u001b[39m'\u001b[39m\u001b[39mexactly\u001b[39m\u001b[39m'\u001b[39m \u001b[39mif\u001b[39;00m \u001b[39mlen\u001b[39m(\u001b[39mcls\u001b[39m\u001b[39m.\u001b[39mnargs) \u001b[39m==\u001b[39m \u001b[39m1\u001b[39m \u001b[39melse\u001b[39;00m \u001b[39m'\u001b[39m\u001b[39mat least\u001b[39m\u001b[39m'\u001b[39m,\n\u001b[1;32m    461\u001b[0m         \u001b[39m'\u001b[39m\u001b[39margs\u001b[39m\u001b[39m'\u001b[39m: \u001b[39mmin\u001b[39m(\u001b[39mcls\u001b[39m\u001b[39m.\u001b[39mnargs),\n\u001b[1;32m    462\u001b[0m         \u001b[39m'\u001b[39m\u001b[39mplural\u001b[39m\u001b[39m'\u001b[39m: \u001b[39m'\u001b[39m\u001b[39ms\u001b[39m\u001b[39m'\u001b[39m\u001b[39m*\u001b[39m(\u001b[39mmin\u001b[39m(\u001b[39mcls\u001b[39m\u001b[39m.\u001b[39mnargs) \u001b[39m!=\u001b[39m \u001b[39m1\u001b[39m),\n\u001b[1;32m    463\u001b[0m         \u001b[39m'\u001b[39m\u001b[39mgiven\u001b[39m\u001b[39m'\u001b[39m: n})\n\u001b[1;32m    465\u001b[0m evaluate \u001b[39m=\u001b[39m options\u001b[39m.\u001b[39mget(\u001b[39m'\u001b[39m\u001b[39mevaluate\u001b[39m\u001b[39m'\u001b[39m, global_parameters\u001b[39m.\u001b[39mevaluate)\n\u001b[0;32m--> 466\u001b[0m result \u001b[39m=\u001b[39m \u001b[39msuper\u001b[39;49m()\u001b[39m.\u001b[39;49m\u001b[39m__new__\u001b[39;49m(\u001b[39mcls\u001b[39;49m, \u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49moptions)\n\u001b[1;32m    467\u001b[0m \u001b[39mif\u001b[39;00m evaluate \u001b[39mand\u001b[39;00m \u001b[39misinstance\u001b[39m(result, \u001b[39mcls\u001b[39m) \u001b[39mand\u001b[39;00m result\u001b[39m.\u001b[39margs:\n\u001b[1;32m    468\u001b[0m     _should_evalf \u001b[39m=\u001b[39m [\u001b[39mcls\u001b[39m\u001b[39m.\u001b[39m_should_evalf(a) \u001b[39mfor\u001b[39;00m a \u001b[39min\u001b[39;00m result\u001b[39m.\u001b[39margs]\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/cache.py:72\u001b[0m, in \u001b[0;36m__cacheit.<locals>.func_wrapper.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     69\u001b[0m \u001b[39m@wraps\u001b[39m(func)\n\u001b[1;32m     70\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mwrapper\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m     71\u001b[0m     \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 72\u001b[0m         retval \u001b[39m=\u001b[39m cfunc(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m     73\u001b[0m     \u001b[39mexcept\u001b[39;00m \u001b[39mTypeError\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m     74\u001b[0m         \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs \u001b[39mor\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs[\u001b[39m0\u001b[39m]\u001b[39m.\u001b[39mstartswith(\u001b[39m'\u001b[39m\u001b[39munhashable type:\u001b[39m\u001b[39m'\u001b[39m):\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/function.py:307\u001b[0m, in \u001b[0;36mApplication.__new__\u001b[0;34m(cls, *args, **options)\u001b[0m\n\u001b[1;32m    304\u001b[0m     \u001b[39mraise\u001b[39;00m \u001b[39mValueError\u001b[39;00m(\u001b[39m\"\u001b[39m\u001b[39mUnknown options: \u001b[39m\u001b[39m%s\u001b[39;00m\u001b[39m\"\u001b[39m \u001b[39m%\u001b[39m options)\n\u001b[1;32m    306\u001b[0m \u001b[39mif\u001b[39;00m evaluate:\n\u001b[0;32m--> 307\u001b[0m     evaluated \u001b[39m=\u001b[39m \u001b[39mcls\u001b[39;49m\u001b[39m.\u001b[39;49meval(\u001b[39m*\u001b[39;49margs)\n\u001b[1;32m    308\u001b[0m     \u001b[39mif\u001b[39;00m evaluated \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    309\u001b[0m         \u001b[39mreturn\u001b[39;00m evaluated\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/functions/elementary/exponential.py:303\u001b[0m, in \u001b[0;36mexp.eval\u001b[0;34m(cls, arg)\u001b[0m\n\u001b[1;32m    301\u001b[0m     \u001b[39mreturn\u001b[39;00m arg\u001b[39m.\u001b[39m_eval_func(\u001b[39mcls\u001b[39m)\n\u001b[1;32m    302\u001b[0m \u001b[39melif\u001b[39;00m arg\u001b[39m.\u001b[39mis_Mul:\n\u001b[0;32m--> 303\u001b[0m     coeff \u001b[39m=\u001b[39m arg\u001b[39m.\u001b[39;49mas_coefficient(pi\u001b[39m*\u001b[39;49mI)\n\u001b[1;32m    304\u001b[0m     \u001b[39mif\u001b[39;00m coeff:\n\u001b[1;32m    305\u001b[0m         \u001b[39mif\u001b[39;00m (\u001b[39m2\u001b[39m\u001b[39m*\u001b[39mcoeff)\u001b[39m.\u001b[39mis_integer:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:1711\u001b[0m, in \u001b[0;36mExpr.as_coefficient\u001b[0;34m(self, expr)\u001b[0m\n\u001b[1;32m   1647\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mas_coefficient\u001b[39m(\u001b[39mself\u001b[39m, expr):\n\u001b[1;32m   1648\u001b[0m \u001b[39m    \u001b[39m\u001b[39m\"\"\"\u001b[39;00m\n\u001b[1;32m   1649\u001b[0m \u001b[39m    Extracts symbolic coefficient at the given expression. In\u001b[39;00m\n\u001b[1;32m   1650\u001b[0m \u001b[39m    other words, this functions separates 'self' into the product\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   1708\u001b[0m \n\u001b[1;32m   1709\u001b[0m \u001b[39m    \"\"\"\u001b[39;00m\n\u001b[0;32m-> 1711\u001b[0m     r \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mextract_multiplicatively(expr)\n\u001b[1;32m   1712\u001b[0m     \u001b[39mif\u001b[39;00m r \u001b[39mand\u001b[39;00m \u001b[39mnot\u001b[39;00m r\u001b[39m.\u001b[39mhas(expr):\n\u001b[1;32m   1713\u001b[0m         \u001b[39mreturn\u001b[39;00m r\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:2246\u001b[0m, in \u001b[0;36mExpr.extract_multiplicatively\u001b[0;34m(self, c)\u001b[0m\n\u001b[1;32m   2244\u001b[0m \u001b[39mif\u001b[39;00m c\u001b[39m.\u001b[39mis_Mul:\n\u001b[1;32m   2245\u001b[0m     a, b \u001b[39m=\u001b[39m c\u001b[39m.\u001b[39mas_two_terms()\n\u001b[0;32m-> 2246\u001b[0m     x \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mextract_multiplicatively(a)\n\u001b[1;32m   2247\u001b[0m     \u001b[39mif\u001b[39;00m x \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m   2248\u001b[0m         \u001b[39mreturn\u001b[39;00m x\u001b[39m.\u001b[39mextract_multiplicatively(b)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:2252\u001b[0m, in \u001b[0;36mExpr.extract_multiplicatively\u001b[0;34m(self, c)\u001b[0m\n\u001b[1;32m   2249\u001b[0m     \u001b[39melse\u001b[39;00m:\n\u001b[1;32m   2250\u001b[0m         \u001b[39mreturn\u001b[39;00m x\n\u001b[0;32m-> 2252\u001b[0m quotient \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m \u001b[39m/\u001b[39;49m c\n\u001b[1;32m   2253\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mis_Number:\n\u001b[1;32m   2254\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m \u001b[39mis\u001b[39;00m S\u001b[39m.\u001b[39mInfinity:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/decorators.py:236\u001b[0m, in \u001b[0;36m_SympifyWrapper.make_wrapped.<locals>._func\u001b[0;34m(self, other)\u001b[0m\n\u001b[1;32m    234\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39misinstance\u001b[39m(other, expectedcls):\n\u001b[1;32m    235\u001b[0m     \u001b[39mreturn\u001b[39;00m retval\n\u001b[0;32m--> 236\u001b[0m \u001b[39mreturn\u001b[39;00m func(\u001b[39mself\u001b[39;49m, other)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/decorators.py:106\u001b[0m, in \u001b[0;36mcall_highest_priority.<locals>.priority_decorator.<locals>.binary_op_wrapper\u001b[0;34m(self, other)\u001b[0m\n\u001b[1;32m    104\u001b[0m         \u001b[39mif\u001b[39;00m f \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[1;32m    105\u001b[0m             \u001b[39mreturn\u001b[39;00m f(\u001b[39mself\u001b[39m)\n\u001b[0;32m--> 106\u001b[0m \u001b[39mreturn\u001b[39;00m func(\u001b[39mself\u001b[39;49m, other)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:259\u001b[0m, in \u001b[0;36mExpr.__truediv__\u001b[0;34m(self, other)\u001b[0m\n\u001b[1;32m    257\u001b[0m     \u001b[39mreturn\u001b[39;00m denom\n\u001b[1;32m    258\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[0;32m--> 259\u001b[0m     \u001b[39mreturn\u001b[39;00m Mul(\u001b[39mself\u001b[39;49m, denom)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/cache.py:72\u001b[0m, in \u001b[0;36m__cacheit.<locals>.func_wrapper.<locals>.wrapper\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m     69\u001b[0m \u001b[39m@wraps\u001b[39m(func)\n\u001b[1;32m     70\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mwrapper\u001b[39m(\u001b[39m*\u001b[39margs, \u001b[39m*\u001b[39m\u001b[39m*\u001b[39mkwargs):\n\u001b[1;32m     71\u001b[0m     \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m---> 72\u001b[0m         retval \u001b[39m=\u001b[39m cfunc(\u001b[39m*\u001b[39;49margs, \u001b[39m*\u001b[39;49m\u001b[39m*\u001b[39;49mkwargs)\n\u001b[1;32m     73\u001b[0m     \u001b[39mexcept\u001b[39;00m \u001b[39mTypeError\u001b[39;00m \u001b[39mas\u001b[39;00m e:\n\u001b[1;32m     74\u001b[0m         \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs \u001b[39mor\u001b[39;00m \u001b[39mnot\u001b[39;00m e\u001b[39m.\u001b[39margs[\u001b[39m0\u001b[39m]\u001b[39m.\u001b[39mstartswith(\u001b[39m'\u001b[39m\u001b[39munhashable type:\u001b[39m\u001b[39m'\u001b[39m):\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/operations.py:98\u001b[0m, in \u001b[0;36mAssocOp.__new__\u001b[0;34m(cls, evaluate, _sympify, *args)\u001b[0m\n\u001b[1;32m     95\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mlen\u001b[39m(args) \u001b[39m==\u001b[39m \u001b[39m1\u001b[39m:\n\u001b[1;32m     96\u001b[0m     \u001b[39mreturn\u001b[39;00m args[\u001b[39m0\u001b[39m]\n\u001b[0;32m---> 98\u001b[0m c_part, nc_part, order_symbols \u001b[39m=\u001b[39m \u001b[39mcls\u001b[39;49m\u001b[39m.\u001b[39;49mflatten(args)\n\u001b[1;32m     99\u001b[0m is_commutative \u001b[39m=\u001b[39m \u001b[39mnot\u001b[39;00m nc_part\n\u001b[1;32m    100\u001b[0m obj \u001b[39m=\u001b[39m \u001b[39mcls\u001b[39m\u001b[39m.\u001b[39m_from_args(c_part \u001b[39m+\u001b[39m nc_part, is_commutative)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/mul.py:285\u001b[0m, in \u001b[0;36mMul.flatten\u001b[0;34m(cls, seq)\u001b[0m\n\u001b[1;32m    283\u001b[0m     seq \u001b[39m=\u001b[39m [a, b]\n\u001b[1;32m    284\u001b[0m \u001b[39massert\u001b[39;00m a \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m S\u001b[39m.\u001b[39mOne\n\u001b[0;32m--> 285\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m a\u001b[39m.\u001b[39;49mis_zero \u001b[39mand\u001b[39;00m a\u001b[39m.\u001b[39mis_Rational:\n\u001b[1;32m    286\u001b[0m     r, b \u001b[39m=\u001b[39m b\u001b[39m.\u001b[39mas_coeff_Mul()\n\u001b[1;32m    287\u001b[0m     \u001b[39mif\u001b[39;00m b\u001b[39m.\u001b[39mis_Add:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:503\u001b[0m, in \u001b[0;36mmake_property.<locals>.getit\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    501\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_assumptions \u001b[39mis\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mdefault_assumptions:\n\u001b[1;32m    502\u001b[0m     \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_assumptions \u001b[39m=\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mdefault_assumptions\u001b[39m.\u001b[39mcopy()\n\u001b[0;32m--> 503\u001b[0m \u001b[39mreturn\u001b[39;00m _ask(fact, \u001b[39mself\u001b[39;49m)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:559\u001b[0m, in \u001b[0;36m_ask\u001b[0;34m(fact, obj)\u001b[0m\n\u001b[1;32m    557\u001b[0m handler_i \u001b[39m=\u001b[39m handler_map\u001b[39m.\u001b[39mget(fact_i)\n\u001b[1;32m    558\u001b[0m \u001b[39mif\u001b[39;00m handler_i \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[0;32m--> 559\u001b[0m     fact_i_value \u001b[39m=\u001b[39m handler_i(obj)\n\u001b[1;32m    561\u001b[0m \u001b[39m# If we get a new value for fact_i then we should update our knowledge\u001b[39;00m\n\u001b[1;32m    562\u001b[0m \u001b[39m# of fact_i as well as any related facts that can be inferred using the\u001b[39;00m\n\u001b[1;32m    563\u001b[0m \u001b[39m# inference rules connecting the fact_i and any other fact values that\u001b[39;00m\n\u001b[1;32m    564\u001b[0m \u001b[39m# are already known.\u001b[39;00m\n\u001b[1;32m    565\u001b[0m \u001b[39mif\u001b[39;00m fact_i_value \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/mul.py:1347\u001b[0m, in \u001b[0;36mMul._eval_is_zero\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m   1344\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39m_eval_is_zero\u001b[39m(\u001b[39mself\u001b[39m):\n\u001b[1;32m   1345\u001b[0m     \u001b[39m# True iff any arg is zero and no arg is infinite but need to handle\u001b[39;00m\n\u001b[1;32m   1346\u001b[0m     \u001b[39m# three valued logic carefully.\u001b[39;00m\n\u001b[0;32m-> 1347\u001b[0m     seen_zero, seen_infinite \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_eval_is_zero_infinite_helper()\n\u001b[1;32m   1349\u001b[0m     \u001b[39mif\u001b[39;00m seen_zero \u001b[39mis\u001b[39;00m \u001b[39mFalse\u001b[39;00m:\n\u001b[1;32m   1350\u001b[0m         \u001b[39mreturn\u001b[39;00m \u001b[39mFalse\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/mul.py:1324\u001b[0m, in \u001b[0;36mMul._eval_is_zero_infinite_helper\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m   1321\u001b[0m seen_zero \u001b[39m=\u001b[39m seen_infinite \u001b[39m=\u001b[39m \u001b[39mFalse\u001b[39;00m\n\u001b[1;32m   1323\u001b[0m \u001b[39mfor\u001b[39;00m a \u001b[39min\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39margs:\n\u001b[0;32m-> 1324\u001b[0m     \u001b[39mif\u001b[39;00m a\u001b[39m.\u001b[39;49mis_zero:\n\u001b[1;32m   1325\u001b[0m         \u001b[39mif\u001b[39;00m seen_infinite \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mFalse\u001b[39;00m:\n\u001b[1;32m   1326\u001b[0m             \u001b[39mreturn\u001b[39;00m \u001b[39mNone\u001b[39;00m, \u001b[39mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:503\u001b[0m, in \u001b[0;36mmake_property.<locals>.getit\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    501\u001b[0m \u001b[39mif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_assumptions \u001b[39mis\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mdefault_assumptions:\n\u001b[1;32m    502\u001b[0m     \u001b[39mself\u001b[39m\u001b[39m.\u001b[39m_assumptions \u001b[39m=\u001b[39m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mdefault_assumptions\u001b[39m.\u001b[39mcopy()\n\u001b[0;32m--> 503\u001b[0m \u001b[39mreturn\u001b[39;00m _ask(fact, \u001b[39mself\u001b[39;49m)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/assumptions.py:559\u001b[0m, in \u001b[0;36m_ask\u001b[0;34m(fact, obj)\u001b[0m\n\u001b[1;32m    557\u001b[0m handler_i \u001b[39m=\u001b[39m handler_map\u001b[39m.\u001b[39mget(fact_i)\n\u001b[1;32m    558\u001b[0m \u001b[39mif\u001b[39;00m handler_i \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n\u001b[0;32m--> 559\u001b[0m     fact_i_value \u001b[39m=\u001b[39m handler_i(obj)\n\u001b[1;32m    561\u001b[0m \u001b[39m# If we get a new value for fact_i then we should update our knowledge\u001b[39;00m\n\u001b[1;32m    562\u001b[0m \u001b[39m# of fact_i as well as any related facts that can be inferred using the\u001b[39;00m\n\u001b[1;32m    563\u001b[0m \u001b[39m# inference rules connecting the fact_i and any other fact values that\u001b[39;00m\n\u001b[1;32m    564\u001b[0m \u001b[39m# are already known.\u001b[39;00m\n\u001b[1;32m    565\u001b[0m \u001b[39mif\u001b[39;00m fact_i_value \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:894\u001b[0m, in \u001b[0;36mExpr._eval_is_extended_negative\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    893\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39m_eval_is_extended_negative\u001b[39m(\u001b[39mself\u001b[39m):\n\u001b[0;32m--> 894\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_eval_is_extended_positive_negative(positive\u001b[39m=\u001b[39;49m\u001b[39mFalse\u001b[39;49;00m)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/expr.py:870\u001b[0m, in \u001b[0;36mExpr._eval_is_extended_positive_negative\u001b[0;34m(self, positive)\u001b[0m\n\u001b[1;32m    867\u001b[0m \u001b[39mif\u001b[39;00m n2 \u001b[39mis\u001b[39;00m S\u001b[39m.\u001b[39mNaN:\n\u001b[1;32m    868\u001b[0m     \u001b[39mreturn\u001b[39;00m \u001b[39mNone\u001b[39;00m\n\u001b[0;32m--> 870\u001b[0m f \u001b[39m=\u001b[39m \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49mevalf(\u001b[39m2\u001b[39;49m)\n\u001b[1;32m    871\u001b[0m \u001b[39mif\u001b[39;00m f\u001b[39m.\u001b[39mis_Float:\n\u001b[1;32m    872\u001b[0m     match \u001b[39m=\u001b[39m f, S\u001b[39m.\u001b[39mZero\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:1647\u001b[0m, in \u001b[0;36mEvalfMixin.evalf\u001b[0;34m(self, n, subs, maxn, chop, strict, quad, verbose)\u001b[0m\n\u001b[1;32m   1645\u001b[0m     options[\u001b[39m'\u001b[39m\u001b[39mquad\u001b[39m\u001b[39m'\u001b[39m] \u001b[39m=\u001b[39m quad\n\u001b[1;32m   1646\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[0;32m-> 1647\u001b[0m     result \u001b[39m=\u001b[39m evalf(\u001b[39mself\u001b[39;49m, prec \u001b[39m+\u001b[39;49m \u001b[39m4\u001b[39;49m, options)\n\u001b[1;32m   1648\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mNotImplementedError\u001b[39;00m:\n\u001b[1;32m   1649\u001b[0m     \u001b[39m# Fall back to the ordinary evalf\u001b[39;00m\n\u001b[1;32m   1650\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mhasattr\u001b[39m(\u001b[39mself\u001b[39m, \u001b[39m'\u001b[39m\u001b[39msubs\u001b[39m\u001b[39m'\u001b[39m) \u001b[39mand\u001b[39;00m subs \u001b[39mis\u001b[39;00m \u001b[39mnot\u001b[39;00m \u001b[39mNone\u001b[39;00m:  \u001b[39m# issue 20291\u001b[39;00m\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:1482\u001b[0m, in \u001b[0;36mevalf\u001b[0;34m(x, prec, options)\u001b[0m\n\u001b[1;32m   1480\u001b[0m \u001b[39mtry\u001b[39;00m:\n\u001b[1;32m   1481\u001b[0m     rf \u001b[39m=\u001b[39m evalf_table[\u001b[39mtype\u001b[39m(x)]\n\u001b[0;32m-> 1482\u001b[0m     r \u001b[39m=\u001b[39m rf(x, prec, options)\n\u001b[1;32m   1483\u001b[0m \u001b[39mexcept\u001b[39;00m \u001b[39mKeyError\u001b[39;00m:\n\u001b[1;32m   1484\u001b[0m     \u001b[39m# Fall back to ordinary evalf if possible\u001b[39;00m\n\u001b[1;32m   1485\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39m'\u001b[39m\u001b[39msubs\u001b[39m\u001b[39m'\u001b[39m \u001b[39min\u001b[39;00m options:\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:478\u001b[0m, in \u001b[0;36mevalf_floor\u001b[0;34m(expr, prec, options)\u001b[0m\n\u001b[1;32m    477\u001b[0m \u001b[39mdef\u001b[39;00m \u001b[39mevalf_floor\u001b[39m(expr: \u001b[39m'\u001b[39m\u001b[39mfloor\u001b[39m\u001b[39m'\u001b[39m, prec: \u001b[39mint\u001b[39m, options: OPT_DICT) \u001b[39m-\u001b[39m\u001b[39m>\u001b[39m TMP_RES:\n\u001b[0;32m--> 478\u001b[0m     \u001b[39mreturn\u001b[39;00m get_integer_part(expr\u001b[39m.\u001b[39;49margs[\u001b[39m0\u001b[39;49m], \u001b[39m-\u001b[39;49m\u001b[39m1\u001b[39;49m, options)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:464\u001b[0m, in \u001b[0;36mget_integer_part\u001b[0;34m(expr, no, options, return_ints)\u001b[0m\n\u001b[1;32m    461\u001b[0m re_, im_, re_acc, im_acc \u001b[39m=\u001b[39m \u001b[39mNone\u001b[39;00m, \u001b[39mNone\u001b[39;00m, \u001b[39mNone\u001b[39;00m, \u001b[39mNone\u001b[39;00m\n\u001b[1;32m    463\u001b[0m \u001b[39mif\u001b[39;00m ire:\n\u001b[0;32m--> 464\u001b[0m     re_, re_acc \u001b[39m=\u001b[39m calc_part(re(expr, evaluate\u001b[39m=\u001b[39;49m\u001b[39mFalse\u001b[39;49;00m), ire)\n\u001b[1;32m    465\u001b[0m \u001b[39mif\u001b[39;00m iim:\n\u001b[1;32m    466\u001b[0m     im_, im_acc \u001b[39m=\u001b[39m calc_part(im(expr, evaluate\u001b[39m=\u001b[39m\u001b[39mFalse\u001b[39;00m), iim)\n",
      "File \u001b[0;32m~/miniconda3/envs/integrator/lib/python3.12/site-packages/sympy/core/evalf.py:455\u001b[0m, in \u001b[0;36mget_integer_part.<locals>.calc_part\u001b[0;34m(re_im, nexpr)\u001b[0m\n\u001b[1;32m    453\u001b[0m \u001b[39mexcept\u001b[39;00m PrecisionExhausted:\n\u001b[1;32m    454\u001b[0m     \u001b[39mif\u001b[39;00m \u001b[39mnot\u001b[39;00m re_im\u001b[39m.\u001b[39mequals(\u001b[39m0\u001b[39m):\n\u001b[0;32m--> 455\u001b[0m         \u001b[39mraise\u001b[39;00m PrecisionExhausted\n\u001b[1;32m    456\u001b[0m     x \u001b[39m=\u001b[39m fzero\n\u001b[1;32m    457\u001b[0m nint \u001b[39m+\u001b[39m\u001b[39m=\u001b[39m \u001b[39mint\u001b[39m(no\u001b[39m*\u001b[39m(mpf_cmp(x \u001b[39mor\u001b[39;00m fzero, fzero) \u001b[39m==\u001b[39m no))\n",
      "\u001b[0;31mPrecisionExhausted\u001b[0m: "
     ]
    }
   ],
   "source": [
    "decompose_steps(f,x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PartsRule(integrand=x**2*cos(x + 2), variable=x, u=x**2, dv=cos(x + 2), v_step=URule(integrand=cos(x + 2), variable=x, u_var=_u, u_func=x + 2, substep=CosRule(integrand=cos(_u), variable=_u)), second_step=PartsRule(integrand=2*x*sin(x + 2), variable=x, u=2*x, dv=sin(x + 2), v_step=URule(integrand=sin(x + 2), variable=x, u_var=_u, u_func=x + 2, substep=SinRule(integrand=sin(_u), variable=_u)), second_step=ConstantTimesRule(integrand=-2*cos(x + 2), variable=x, constant=-2, other=cos(x + 2), substep=URule(integrand=cos(x + 2), variable=x, u_var=_u, u_func=x + 2, substep=CosRule(integrand=cos(_u), variable=_u)))))"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "u = sp.Symbol('u')\n",
    "integral_steps(x**2 * sp.cos(x + 2), x)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integral(x**2*cos(x + 2), x) -> x**2*Integral(cos(x + 2), x) - Integral(2*x*Integral(cos(x + 2), x), x) using ('PartsRule', x**2, cos(x + 2)) at Integral(x**2*cos(x + 2), x)\n",
      "x**2*Integral(cos(x + 2), x) - Integral(2*x*Integral(cos(x + 2), x), x) -> x**2*Integral(cos(y), y) - Integral(2*x*Integral(cos(y), y), x) using ('URule', y, x + 2) at Integral(cos(x + 2), x)\n",
      "x**2*Integral(cos(y), y) - Integral(2*x*Integral(cos(y), y), x) -> x**2*sin(y) - Integral(2*x*sin(y), x) using ('CosRule',) at Integral(cos(y), y)\n",
      "x**2*sin(y) - Integral(2*x*sin(y), x) -> x**2*sin(x + 2) - 2*Integral(x*sin(x + 2), x) using ('ConstantTimesRule',) at Integral(2*x*sin(x + 2), x)\n",
      "x**2*sin(x + 2) - 2*Integral(x*sin(x + 2), x) -> x**2*sin(x + 2) - 2*x*Integral(sin(x + 2), x) + 2*Integral(sin(x + 2), x, x) using ('PartsRule', x, sin(x + 2)) at Integral(x*sin(x + 2), x)\n",
      "x**2*sin(x + 2) - 2*x*Integral(sin(x + 2), x) + 2*Integral(sin(x + 2), x, x) -> x**2*sin(x + 2) - 2*x*Integral(sin(y), y) + 2*Integral(sin(y), y, x) using ('URule', y, x + 2) at Integral(sin(x + 2), x)\n",
      "x**2*sin(x + 2) - 2*x*Integral(sin(y), y) + 2*Integral(sin(y), y, x) -> x**2*sin(x + 2) + 2*x*cos(y) + 2*Integral(-cos(y), x) using ('SinRule',) at Integral(sin(y), y)\n",
      "x**2*sin(x + 2) + 2*x*cos(y) + 2*Integral(-cos(y), x) -> x**2*sin(x + 2) + 2*x*cos(x + 2) - 2*Integral(cos(x + 2), x) using ('ConstantTimesRule',) at Integral(-cos(x + 2), x)\n",
      "x**2*sin(x + 2) + 2*x*cos(x + 2) - 2*Integral(cos(x + 2), x) -> x**2*sin(x + 2) + 2*x*cos(x + 2) - 2*Integral(cos(y), y) using ('URule', y, x + 2) at Integral(cos(x + 2), x)\n",
      "x**2*sin(x + 2) + 2*x*cos(x + 2) - 2*Integral(cos(y), y) -> x**2*sin(x + 2) + 2*x*cos(x + 2) - 2*sin(y) using ('CosRule',) at Integral(cos(y), y)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(steps_to_string(decompose_steps(x**2 * sp.cos(x + 2), x)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(x**2*log(x), u, log(x))"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from method import UMethod\n",
    "x = sp.Symbol('x')\n",
    "f = x*sp.log(x)\n",
    "u = sp.Symbol('u')\n",
    "u_func = sp.log(x)\n",
    "f = f/sp.diff(u_func, x)\n",
    "f = f.subs(u, u_func)\n",
    "#UMethod(u, u_func).apply(sp.Integral(f,x))\n",
    "f, u, u_func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ConstantTimesRule(integrand=x/(sqrt(x**3)*sin(3)), variable=x, constant=1/sin(3), other=x/sqrt(x**3), substep=NestedPowRule(integrand=x/sqrt(x**3), variable=x, base=x, exp=-1/2))"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "f = x/(sp.sqrt(x**3)*sp.sin(3))\n",
    "integral_steps(f, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integral(sin(x + 4), x) -> Integral(sin(y), y) using ('URule', y, x + 4) at Integral(sin(x + 4), x)\n",
      "Integral(sin(y), y) -> -cos(y) using ('SinRule',) at Integral(sin(y), y)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(steps_to_string(decompose_steps(f, x)))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Integrand:  E\n",
      "Is constant:  True\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from method import ConstantMethod\n",
    "x = sp.Symbol('x')\n",
    "f = (x**2/2 + sp.Integral(sp.E, x))*sp.sinh(1)\n",
    "subexpr = sp.Integral(sp.E, x)\n",
    "ConstantMethod().apply(subexpr)\n",
    "\n",
    "sp.E.is_constant()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "RewriteRule(integrand=(24*x**7 - 1)*(acos(x) + asin(x)), variable=x, rewritten=24*x**7*acos(x) + 24*x**7*asin(x) - acos(x) - asin(x), substep=AddRule(integrand=24*x**7*acos(x) + 24*x**7*asin(x) - acos(x) - asin(x), variable=x, substeps=[ConstantTimesRule(integrand=24*x**7*acos(x), variable=x, constant=24, other=x**7*acos(x), substep=PartsRule(integrand=x**7*acos(x), variable=x, u=acos(x), dv=x**7, v_step=PowerRule(integrand=x**7, variable=x, base=x, exp=7), second_step=ConstantTimesRule(integrand=-x**8/(8*sqrt(1 - x**2)), variable=x, constant=-1/8, other=x**8/sqrt(1 - x**2), substep=SqrtQuadraticDenomRule(integrand=x**8/sqrt(1 - x**2), variable=x, a=1, b=0, c=-1, coeffs=[1, 0, 0, 0, 0, 0, 0, 0, 0])))), ConstantTimesRule(integrand=24*x**7*asin(x), variable=x, constant=24, other=x**7*asin(x), substep=PartsRule(integrand=x**7*asin(x), variable=x, u=asin(x), dv=x**7, v_step=PowerRule(integrand=x**7, variable=x, base=x, exp=7), second_step=ConstantTimesRule(integrand=x**8/(8*sqrt(1 - x**2)), variable=x, constant=1/8, other=x**8/sqrt(1 - x**2), substep=SqrtQuadraticDenomRule(integrand=x**8/sqrt(1 - x**2), variable=x, a=1, b=0, c=-1, coeffs=[1, 0, 0, 0, 0, 0, 0, 0, 0])))), ConstantTimesRule(integrand=-acos(x), variable=x, constant=-1, other=acos(x), substep=PartsRule(integrand=acos(x), variable=x, u=acos(x), dv=1, v_step=ConstantRule(integrand=1, variable=x), second_step=ConstantTimesRule(integrand=-x/sqrt(1 - x**2), variable=x, constant=-1, other=x/sqrt(1 - x**2), substep=ConstantTimesRule(integrand=x/sqrt(1 - x**2), variable=x, constant=-1/2, other=-2*x/sqrt(1 - x**2), substep=URule(integrand=-2*x/sqrt(1 - x**2), variable=x, u_var=_u, u_func=1 - x**2, substep=PowerRule(integrand=1/sqrt(_u), variable=_u, base=_u, exp=-1/2)))))), ConstantTimesRule(integrand=-asin(x), variable=x, constant=-1, other=asin(x), substep=PartsRule(integrand=asin(x), variable=x, u=asin(x), dv=1, v_step=ConstantRule(integrand=1, variable=x), second_step=ConstantTimesRule(integrand=x/sqrt(1 - x**2), variable=x, constant=-1/2, other=-2*x/sqrt(1 - x**2), substep=URule(integrand=-2*x/sqrt(1 - x**2), variable=x, u_var=_u, u_func=1 - x**2, substep=PowerRule(integrand=1/sqrt(_u), variable=_u, base=_u, exp=-1/2)))))]))"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "f = (24*x**7 - 1)*(sp.acos(x) + sp.asin(x))\n",
    "integral_steps(f,x).alternatives[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{\\log{\\left(x^{2} - 1 \\right)}}{2}$"
      ],
      "text/plain": [
       "log(x**2 - 1)/2"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integral_steps(f,x).eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "'set' object is not subscriptable",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[1;32m/home/ubuntu/mert/alpha_integrate/steps.ipynb Cell 3\u001b[0m line \u001b[0;36m1\n\u001b[0;32m----> <a href='vscode-notebook-cell://ssh-remote%2B150.136.146.76/home/ubuntu/mert/alpha_integrate/steps.ipynb#X40sdnNjb2RlLXJlbW90ZQ%3D%3D?line=0'>1</a>\u001b[0m f\u001b[39m.\u001b[39;49mfree_symbols[\u001b[39m0\u001b[39;49m]\n",
      "\u001b[0;31mTypeError\u001b[0m: 'set' object is not subscriptable"
     ]
    }
   ],
   "source": [
    "expr = sp.Integral(f, x)\n",
    "subexpr = expr\n",
    "step = (expr, subexpr, ('NestedPowRule',))\n",
    "apply_step(step)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{1}{\\left(\\tanh^{2}{\\left(\\frac{x}{2} \\right)} + 1\\right) \\cosh^{2}{\\left(\\frac{x}{2} \\right)}}$"
      ],
      "text/plain": [
       "1/((tanh(x/2)**2 + 1)*cosh(x/2)**2)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sp.simplify(1-sp.tanh(x/2)**2)/(1+sp.tanh(x/2)**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{x \\sqrt{x^{6}}}{4}$"
      ],
      "text/plain": [
       "x*sqrt(x**6)/4"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integral_steps(f, x).eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "1/sp.sqrt(1+x**2) == 1/(1+x**2)**(sp.Rational(1,2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "PartsRule(integrand=x*cos(x), variable=x, u=x, dv=cos(x), v_step=CosRule(integrand=cos(x), variable=x), second_step=SinRule(integrand=sin(x), variable=x))"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "expr = sp.sympify('x*cos(x)')\n",
    "#f = sp.Integral(expr, x)\n",
    "\n",
    "#decompose_steps(f, x)\n",
    "integral_steps(expr, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(Integral((x*log(sqrt(16 - (-pi**2 + 8 + 4*sqrt(5))**2)/4) + 2)/sqrt(1 - x**2), x),\n",
       "  (x*log(sqrt(16 - (-pi**2 + 8 + 4*sqrt(5))**2)/4) + 2)/sqrt(1 - x**2),\n",
       "  ('SqrtQuadraticDenom1',),\n",
       "  Integral(-2*x*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)/sqrt(1 - x**2) + 2/sqrt(1 - x**2), x)),\n",
       " (Integral((x*log(sqrt(16 - (-pi**2 + 8 + 4*sqrt(5))**2)/4) + 2)/sqrt(1 - x**2), x),\n",
       "  Integral(-2*x*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)/sqrt(1 - x**2) + 2/sqrt(1 - x**2), x),\n",
       "  ('AddRule',),\n",
       "  Integral(-2*x*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)/sqrt(1 - x**2), x) + Integral(2/sqrt(1 - x**2), x)),\n",
       " (Integral(-2*x*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)/sqrt(1 - x**2), x) + Integral(2/sqrt(1 - x**2), x),\n",
       "  Integral(-2*x*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)/sqrt(1 - x**2), x),\n",
       "  ('ConstantTimesRule',),\n",
       "  (-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)*Integral(-2*x/sqrt(1 - x**2), x) + Integral(2/sqrt(1 - x**2), x)),\n",
       " ((-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)*Integral(-2*x/sqrt(1 - x**2), x) + Integral(2/sqrt(1 - x**2), x),\n",
       "  Integral(-2*x/sqrt(1 - x**2), x),\n",
       "  ('URule', _u, 1 - x**2),\n",
       "  (-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)*Integral(1/sqrt(_u), _u) + Integral(2/sqrt(1 - x**2), x)),\n",
       " ((-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4)*Integral(1/sqrt(_u), _u) + Integral(2/sqrt(1 - x**2), x),\n",
       "  Integral(1/sqrt(_u), _u),\n",
       "  ('PowerRule',),\n",
       "  2*sqrt(_u)*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4) + Integral(2/sqrt(1 - x**2), x)),\n",
       " (2*sqrt(_u)*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4) + Integral(2/sqrt(1 - x**2), x),\n",
       "  Integral(2/sqrt(1 - x**2), x),\n",
       "  ('ConstantTimesRule',),\n",
       "  2*sqrt(_u)*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4) + 2*Integral(1/sqrt(1 - x**2), x)),\n",
       " (2*sqrt(_u)*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4) + 2*Integral(1/sqrt(1 - x**2), x),\n",
       "  Integral(1/sqrt(1 - x**2), x),\n",
       "  ('ArcsinRule',),\n",
       "  2*sqrt(_u)*(-log(-8*sqrt(5)*pi**2 - 16*pi**2 + pi**4 + 128 + 64*sqrt(5))/4 + log(2) - I*pi/4) + 2*asin(x))]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "decompose_steps(expr, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ConstantTimesRule(integrand=3*x*(x + (4 - 3*x**2)/x)*log(x), variable=x, constant=3, other=x*(x + (4 - 3*x**2)/x)*log(x), substep=AlternativeRule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, alternatives=[AlternativeRule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, alternatives=[URule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, u_var=_u, u_func=1/x, substep=AlternativeRule(integrand=(-4*_u**2*log(1/_u) + 2*log(1/_u))/_u**4, variable=_u, alternatives=[AlternativeRule(integrand=(-4*_u**2*log(1/_u) + 2*log(1/_u))/_u**4, variable=_u, alternatives=[URule(integrand=(-4*_u**2*log(1/_u) + 2*log(1/_u))/_u**4, variable=_u, u_var=_u, u_func=log(1/_u), substep=AddRule(integrand=-2*_u*exp(3*_u) + 4*_u*exp(_u), variable=_u, substeps=[ConstantTimesRule(integrand=-2*_u*exp(3*_u), variable=_u, constant=-2, other=_u*exp(3*_u), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), ConstantTimesRule(integrand=4*_u*exp(_u), variable=_u, constant=4, other=_u*exp(_u), substep=PartsRule(integrand=_u*exp(_u), variable=_u, u=_u, dv=exp(_u), v_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u), second_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u)))])), URule(integrand=(-4*_u**2*log(1/_u) + 2*log(1/_u))/_u**4, variable=_u, u_var=_u, u_func=1/_u, substep=AddRule(integrand=-2*_u**2*log(_u) + 4*log(_u), variable=_u, substeps=[ConstantTimesRule(integrand=-2*_u**2*log(_u), variable=_u, constant=-2, other=_u**2*log(_u), substep=AlternativeRule(integrand=_u**2*log(_u), variable=_u, alternatives=[URule(integrand=_u**2*log(_u), variable=_u, u_var=_u, u_func=log(_u), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), PartsRule(integrand=_u**2*log(_u), variable=_u, u=log(_u), dv=_u**2, v_step=PowerRule(integrand=_u**2, variable=_u, base=_u, exp=2), second_step=ConstantTimesRule(integrand=_u**2/3, variable=_u, constant=1/3, other=_u**2, substep=PowerRule(integrand=_u**2, variable=_u, base=_u, exp=2)))])), ConstantTimesRule(integrand=4*log(_u), variable=_u, constant=4, other=log(_u), substep=PartsRule(integrand=log(_u), variable=_u, u=log(_u), dv=1, v_step=ConstantRule(integrand=1, variable=_u), second_step=ConstantRule(integrand=1, variable=_u)))]))]), RewriteRule(integrand=(-4*_u**2*log(1/_u) + 2*log(1/_u))/_u**4, variable=_u, rewritten=-4*log(1/_u)/_u**2 + 2*log(1/_u)/_u**4, substep=AddRule(integrand=-4*log(1/_u)/_u**2 + 2*log(1/_u)/_u**4, variable=_u, substeps=[ConstantTimesRule(integrand=-4*log(1/_u)/_u**2, variable=_u, constant=-4, other=log(1/_u)/_u**2, substep=AlternativeRule(integrand=log(1/_u)/_u**2, variable=_u, alternatives=[AlternativeRule(integrand=log(1/_u)/_u**2, variable=_u, alternatives=[URule(integrand=log(1/_u)/_u**2, variable=_u, u_var=_u, u_func=log(1/_u), substep=ConstantTimesRule(integrand=-_u*exp(_u), variable=_u, constant=-1, other=_u*exp(_u), substep=PartsRule(integrand=_u*exp(_u), variable=_u, u=_u, dv=exp(_u), v_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u), second_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u)))), URule(integrand=log(1/_u)/_u**2, variable=_u, u_var=_u, u_func=1/_u, substep=ConstantTimesRule(integrand=-log(_u), variable=_u, constant=-1, other=log(_u), substep=PartsRule(integrand=log(_u), variable=_u, u=log(_u), dv=1, v_step=ConstantRule(integrand=1, variable=_u), second_step=ConstantRule(integrand=1, variable=_u))))]), PartsRule(integrand=log(1/_u)/_u**2, variable=_u, u=log(1/_u), dv=_u**(-2), v_step=PowerRule(integrand=_u**(-2), variable=_u, base=_u, exp=-2), second_step=PowerRule(integrand=_u**(-2), variable=_u, base=_u, exp=-2))])), ConstantTimesRule(integrand=2*log(1/_u)/_u**4, variable=_u, constant=2, other=log(1/_u)/_u**4, substep=AlternativeRule(integrand=log(1/_u)/_u**4, variable=_u, alternatives=[AlternativeRule(integrand=log(1/_u)/_u**4, variable=_u, alternatives=[URule(integrand=log(1/_u)/_u**4, variable=_u, u_var=_u, u_func=log(1/_u), substep=ConstantTimesRule(integrand=-_u*exp(3*_u), variable=_u, constant=-1, other=_u*exp(3*_u), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]))))), URule(integrand=log(1/_u)/_u**4, variable=_u, u_var=_u, u_func=1/_u, substep=ConstantTimesRule(integrand=-_u**2*log(_u), variable=_u, constant=-1, other=_u**2*log(_u), substep=AlternativeRule(integrand=_u**2*log(_u), variable=_u, alternatives=[URule(integrand=_u**2*log(_u), variable=_u, u_var=_u, u_func=log(_u), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), PartsRule(integrand=_u**2*log(_u), variable=_u, u=log(_u), dv=_u**2, v_step=PowerRule(integrand=_u**2, variable=_u, base=_u, exp=2), second_step=ConstantTimesRule(integrand=_u**2/3, variable=_u, constant=1/3, other=_u**2, substep=PowerRule(integrand=_u**2, variable=_u, base=_u, exp=2)))])))]), PartsRule(integrand=log(1/_u)/_u**4, variable=_u, u=log(1/_u), dv=_u**(-4), v_step=PowerRule(integrand=_u**(-4), variable=_u, base=_u, exp=-4), second_step=ConstantTimesRule(integrand=1/(3*_u**4), variable=_u, constant=1/3, other=_u**(-4), substep=PowerRule(integrand=_u**(-4), variable=_u, base=_u, exp=-4)))]))]))])), URule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, u_var=_u, u_func=log(x), substep=AddRule(integrand=-2*_u*exp(3*_u) + 4*_u*exp(_u), variable=_u, substeps=[ConstantTimesRule(integrand=-2*_u*exp(3*_u), variable=_u, constant=-2, other=_u*exp(3*_u), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), ConstantTimesRule(integrand=4*_u*exp(_u), variable=_u, constant=4, other=_u*exp(_u), substep=PartsRule(integrand=_u*exp(_u), variable=_u, u=_u, dv=exp(_u), v_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u), second_step=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u)))]))]), RewriteRule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, rewritten=-2*x**2*log(x) + 4*log(x), substep=AddRule(integrand=-2*x**2*log(x) + 4*log(x), variable=x, substeps=[ConstantTimesRule(integrand=-2*x**2*log(x), variable=x, constant=-2, other=x**2*log(x), substep=AlternativeRule(integrand=x**2*log(x), variable=x, alternatives=[URule(integrand=x**2*log(x), variable=x, u_var=_u, u_func=log(x), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), PartsRule(integrand=x**2*log(x), variable=x, u=log(x), dv=x**2, v_step=PowerRule(integrand=x**2, variable=x, base=x, exp=2), second_step=ConstantTimesRule(integrand=x**2/3, variable=x, constant=1/3, other=x**2, substep=PowerRule(integrand=x**2, variable=x, base=x, exp=2)))])), ConstantTimesRule(integrand=4*log(x), variable=x, constant=4, other=log(x), substep=PartsRule(integrand=log(x), variable=x, u=log(x), dv=1, v_step=ConstantRule(integrand=1, variable=x), second_step=ConstantRule(integrand=1, variable=x)))])), PartsRule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, u=log(x), dv=x*(x + (4 - 3*x**2)/x), v_step=AddRule(integrand=4 - 2*x**2, variable=x, substeps=[ConstantRule(integrand=4, variable=x), ConstantTimesRule(integrand=-2*x**2, variable=x, constant=-2, other=x**2, substep=PowerRule(integrand=x**2, variable=x, base=x, exp=2))]), second_step=RewriteRule(integrand=(-2*x**3/3 + 4*x)/x, variable=x, rewritten=4 - 2*x**2/3, substep=AddRule(integrand=4 - 2*x**2/3, variable=x, substeps=[ConstantRule(integrand=4, variable=x), ConstantTimesRule(integrand=-2*x**2/3, variable=x, constant=-2/3, other=x**2, substep=PowerRule(integrand=x**2, variable=x, base=x, exp=2))]))), RewriteRule(integrand=x*(x + (4 - 3*x**2)/x)*log(x), variable=x, rewritten=-2*x**2*log(x) + 4*log(x), substep=AddRule(integrand=-2*x**2*log(x) + 4*log(x), variable=x, substeps=[ConstantTimesRule(integrand=-2*x**2*log(x), variable=x, constant=-2, other=x**2*log(x), substep=AlternativeRule(integrand=x**2*log(x), variable=x, alternatives=[URule(integrand=x**2*log(x), variable=x, u_var=_u, u_func=log(x), substep=PartsRule(integrand=_u*exp(3*_u), variable=_u, u=_u, dv=exp(3*_u), v_step=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))]), second_step=ConstantTimesRule(integrand=exp(3*_u)/3, variable=_u, constant=1/3, other=exp(3*_u), substep=AlternativeRule(integrand=exp(3*_u), variable=_u, alternatives=[URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=3*_u, substep=ConstantTimesRule(integrand=exp(_u)/3, variable=_u, constant=1/3, other=exp(_u), substep=ExpRule(integrand=exp(_u), variable=_u, base=E, exp=_u))), URule(integrand=exp(3*_u), variable=_u, u_var=_u, u_func=exp(3*_u), substep=ConstantTimesRule(integrand=1/3, variable=_u, constant=1/3, other=1, substep=ConstantRule(integrand=1, variable=_u)))])))), PartsRule(integrand=x**2*log(x), variable=x, u=log(x), dv=x**2, v_step=PowerRule(integrand=x**2, variable=x, base=x, exp=2), second_step=ConstantTimesRule(integrand=x**2/3, variable=x, constant=1/3, other=x**2, substep=PowerRule(integrand=x**2, variable=x, base=x, exp=2)))])), ConstantTimesRule(integrand=4*log(x), variable=x, constant=4, other=log(x), substep=PartsRule(integrand=log(x), variable=x, u=log(x), dv=1, v_step=ConstantRule(integrand=1, variable=x), second_step=ConstantRule(integrand=1, variable=x)))]))]))"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "f = 3*(x*((x + (4 - 3*x**2)/x)*sp.log(x)))\n",
    "\n",
    "#decompose_steps(f, x)\n",
    "integral_steps(f, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle 2 \\log{\\left(x^{2} + 1 \\right)} + \\operatorname{atan}{\\left(x \\right)}$"
      ],
      "text/plain": [
       "2*log(x**2 + 1) + atan(x)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "manualintegrate(f,x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[(Integral(3*x*(x + (4 - 3*x**2)/x)*log(x), x),\n",
       "  Integral(3*x*(x + (4 - 3*x**2)/x)*log(x), x),\n",
       "  ('ConstantTimesRule',),\n",
       "  3*Integral(x*(x + (4 - 3*x**2)/x)*log(x), x)),\n",
       " (3*Integral(x*(x + (4 - 3*x**2)/x)*log(x), x),\n",
       "  x*(x + (4 - 3*x**2)/x)*log(x),\n",
       "  'Cancel',\n",
       "  -6*x**2*log(x) + 12*log(x)),\n",
       " (-6*x**2*log(x) + 12*log(x),\n",
       "  Integral(-2*x**2*log(x) + 4*log(x), x),\n",
       "  ('AddRule',),\n",
       "  3*Integral(-2*x**2*log(x), x) + 3*Integral(4*log(x), x)),\n",
       " (3*Integral(-2*x**2*log(x), x) + 3*Integral(4*log(x), x),\n",
       "  Integral(-2*x**2*log(x), x),\n",
       "  ('ConstantTimesRule',),\n",
       "  -6*Integral(x**2*log(x), x) + 3*Integral(4*log(x), x)),\n",
       " (-6*Integral(x**2*log(x), x) + 3*Integral(4*log(x), x),\n",
       "  Integral(x**2*log(x), x),\n",
       "  ('URule', _u, log(x)),\n",
       "  -6*Integral(_u*exp(3*_u), _u) + 3*Integral(4*log(x), x)),\n",
       " (-6*Integral(_u*exp(3*_u), _u) + 3*Integral(4*log(x), x),\n",
       "  Integral(_u*exp(3*_u), _u),\n",
       "  ('PartsRule', _u, exp(3*_u)),\n",
       "  -6*_u*Integral(exp(3*_u), _u) + 3*Integral(4*log(x), x) + 6*Integral(exp(3*_u), _u, _u)),\n",
       " (-6*_u*Integral(exp(3*_u), _u) + 3*Integral(4*log(x), x) + 6*Integral(exp(3*_u), _u, _u),\n",
       "  Integral(exp(3*_u), _u),\n",
       "  ('URule', _u, exp(3*_u)),\n",
       "  -6*_u*Integral(1/3, _u) + 3*Integral(4*log(x), x) + 6*Integral(1/3, _u, _u)),\n",
       " (-6*_u*Integral(1/3, _u) + 3*Integral(4*log(x), x) + 6*Integral(1/3, _u, _u),\n",
       "  Integral(1/3, _u),\n",
       "  ('ConstantTimesRule',),\n",
       "  -2*_u*Integral(1, _u) + 3*Integral(4*log(x), x) + 6*Integral(Integral(1, _u)/3, _u)),\n",
       " (-2*_u*Integral(1, _u) + 3*Integral(4*log(x), x) + 6*Integral(Integral(1, _u)/3, _u),\n",
       "  Integral(1, _u),\n",
       "  'ConstantRule',\n",
       "  -2*_u*_u + 6*Integral(_u/3, _u) + 3*Integral(4*log(x), x)),\n",
       " (-2*_u*_u + 6*Integral(_u/3, _u) + 3*Integral(4*log(x), x),\n",
       "  Integral(exp(3*_u)/3, _u),\n",
       "  ('ConstantTimesRule',),\n",
       "  -2*_u*exp(3*_u) + 2*Integral(exp(3*_u), _u) + 3*Integral(4*log(x), x)),\n",
       " (-2*_u*exp(3*_u) + 2*Integral(exp(3*_u), _u) + 3*Integral(4*log(x), x),\n",
       "  Integral(exp(3*_u), _u),\n",
       "  ('URule', _u, exp(3*_u)),\n",
       "  -2*_u*exp(3*_u) + 2*Integral(1/3, _u) + 3*Integral(4*log(x), x)),\n",
       " (-2*_u*exp(3*_u) + 2*Integral(1/3, _u) + 3*Integral(4*log(x), x),\n",
       "  Integral(1/3, _u),\n",
       "  ('ConstantTimesRule',),\n",
       "  -2*_u*exp(3*_u) + 2*Integral(1, _u)/3 + 3*Integral(4*log(x), x)),\n",
       " (-2*_u*exp(3*_u) + 2*Integral(1, _u)/3 + 3*Integral(4*log(x), x),\n",
       "  Integral(1, _u),\n",
       "  'ConstantRule',\n",
       "  -2*_u*exp(3*_u) + 2*_u/3 + 3*Integral(4*log(x), x)),\n",
       " (-2*_u*exp(3*_u) + 2*_u/3 + 3*Integral(4*log(x), x),\n",
       "  Integral(4*log(x), x),\n",
       "  ('ConstantTimesRule',),\n",
       "  -2*_u*exp(3*_u) + 2*_u/3 + 12*Integral(log(x), x)),\n",
       " (-2*_u*exp(3*_u) + 2*_u/3 + 12*Integral(log(x), x),\n",
       "  Integral(log(x), x),\n",
       "  ('PartsRule', log(x), 1, 'ConstantRule'),\n",
       "  -2*_u*exp(3*_u) + 2*_u/3 + 12*x*log(x) - 12*Integral(1, x)),\n",
       " (-2*_u*exp(3*_u) + 2*_u/3 + 12*x*log(x) - 12*Integral(1, x),\n",
       "  Integral(1, x),\n",
       "  'ConstantRule',\n",
       "  -2*_u*exp(3*_u) + 2*_u/3 + 12*x*log(x) - 12*x)]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "decompose_steps(f, x)\n",
    "#f.apart(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f == -1/(x + 1/2) + 1/(x - 1/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RewriteRule(integrand=1/cos(x), variable=x, rewritten=sec(x), substep=RewriteRule(integrand=sec(x), variable=x, rewritten=(tan(x)*sec(x) + sec(x)**2)/(tan(x) + sec(x)), substep=AlternativeRule(integrand=(tan(x)*sec(x) + sec(x)**2)/(tan(x) + sec(x)), variable=x, alternatives=[URule(integrand=(tan(x)*sec(x) + sec(x)**2)/(tan(x) + sec(x)), variable=x, u_var=_u, u_func=tan(x) + sec(x), substep=ReciprocalRule(integrand=1/_u, variable=_u, base=_u))])))\n"
     ]
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "f = 1/(3*x**2 - 5)\n",
    "f = 1/sp.cos(x)\n",
    "#f = sp.sec(x)\n",
    "#print(rewrites_rule((f, x)))\n",
    "\n",
    "steps = integral_steps(f, x)\n",
    "print(steps)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{1 - \\tanh^{2}{\\left(\\frac{x}{2} \\right)}}{\\tanh^{2}{\\left(\\frac{x}{2} \\right)} + 1}$"
      ],
      "text/plain": [
       "(1 - tanh(x/2)**2)/(tanh(x/2)**2 + 1)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f = sp.sech(x)\n",
    "f.rewrite(sp.tanh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle \\frac{1 - \\tanh^{2}{\\left(\\frac{x}{2} \\right)}}{2 \\tanh{\\left(\\frac{x}{2} \\right)}}$"
      ],
      "text/plain": [
       "(1 - tanh(x/2)**2)/(2*tanh(x/2))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f = sp.csch(x)\n",
    "f.rewrite(sp.tanh)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f.match(sp.csch(x)).get(0, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{a_: 1, m_: 2, n_: 0}"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def make_wilds(symbol):\n",
    "    a = Wild('a', exclude=[symbol])\n",
    "    b = Wild('b', exclude=[symbol])\n",
    "    m = Wild('m', exclude=[symbol], properties=[lambda n: isinstance(n, sp.Integer)])\n",
    "    n = Wild('n', exclude=[symbol], properties=[lambda n: isinstance(n, sp.Integer)])\n",
    "\n",
    "    return a, b, m, n\n",
    "\n",
    "def sincos_pattern(symbol):\n",
    "    a, b, m, n = make_wilds(symbol)\n",
    "    pattern = sp.sin(a*symbol)**m * sp.cos(b*symbol)**n\n",
    "\n",
    "    return pattern, a, b, m, n\n",
    "\n",
    "f = sp.sin(x)**2\n",
    "pattern, a, b, m, n = sincos_pattern(x)\n",
    "f.match(pattern)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DontKnowRule(integrand=1/cos(x), variable=x)"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x = sp.Symbol('x')\n",
    "f = 1 + 1/sp.cos(x)\n",
    "integral_steps(f, x)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f.match(a/sp.cos(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{b_: 3, c_: -5, d_: 0, a_: 1}"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "a = Wild('a', exclude=[x])\n",
    "b = Wild('b', exclude=[x])\n",
    "c = Wild('c', exclude=[x])\n",
    "d = Wild('d', exclude=[x])\n",
    "\n",
    "match = f.match(a / (b * x ** 2 + c + d*x))\n",
    "match"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle - \\frac{\\sqrt{\\frac{1}{x^{6}}}}{4 x}$"
      ],
      "text/plain": [
       "-sqrt(x**(-6))/(4*x)"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "f = sp.sqrt(x**(-6))/x**2\n",
    "# given an expression like this, simplify its power\n",
    "integral_steps(f, x).eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sympy as sp\n",
    "\n",
    "from sympy.integrals.manualintegrate import integral_steps\n",
    "from sympy.integrals.manualintegrate import *\n",
    "\n",
    "# Rules that do not have any substeps\n",
    "\n",
    "SIMPLE_STEPS = (ConstantRule, PowerRule, ExpRule, TrigRule, HyperbolicRule, ReciprocalRule, \n",
    "               ArcsinRule, ArcsinhRule, ReciprocalSqrtQuadraticRule, SqrtQuadraticDenomRule, SqrtQuadraticRule,\n",
    "               SinRule, CosRule, SecTanRule, CscCotRule, Sec2Rule, Csc2Rule, SinhRule, CoshRule, ArctanRule)\n",
    "\n",
    "SPECIAL_SIMPLE_STEPS = (OrthogonalPolyRule, JacobiRule, GegenbauerRule, ChebyshevTRule, ChebyshevURule, \n",
    "                        LegendreRule, HermiteRule, LaguerreRule, AssocLaguerreRule, IRule, CiRule, SiRule,\n",
    "                        ChiRule, EiRule, ShiRule, LiRule, ErfRule, FresnelSRule, FresnelCRule, PolylogRule,\n",
    "                        UpperGammaRule, EllipticERule, EllipticFRule)\n",
    "\n",
    "def decompose_steps(expression, symbol, steps = None):\n",
    "\n",
    "    '''\n",
    "    The goal of this function is to decompose the steps of the integration of an expression and generate a list of pairs of\n",
    "    (expression, subexpression at which the rule should be applied, next rule to apply, result after the rule is applied) by taking the expression and applying the rules until the expression is integrated\n",
    "    and recording the expression and the rule that was applied to get to the next step.\n",
    "    '''\n",
    "\n",
    "    tokenizable_steps = []\n",
    "\n",
    "    integral = sp.Integral(expression, symbol)\n",
    "\n",
    "    if steps is None:\n",
    "        steps = integral_steps(expression, symbol)\n",
    "\n",
    "    if steps.contains_dont_know():\n",
    "        return [None]\n",
    "    \n",
    "    #print(\"Integral: \", integral)\n",
    "    #print(\"Steps: \", steps)\n",
    "\n",
    "\n",
    "    if isinstance(steps, SIMPLE_STEPS):\n",
    "        tokenizable_steps.append((integral, integral, steps.__class__.__name__, steps.eval()))\n",
    "    \n",
    "    if isinstance(steps, SPECIAL_SIMPLE_STEPS):\n",
    "        tokenizable_steps.append((integral, integral, steps.__class__.__name__, steps.eval()))\n",
    "\n",
    "    if isinstance(steps, AddRule):\n",
    "        \n",
    "\n",
    "        integrand = steps.integrand\n",
    "        symbol = steps.variable\n",
    "        integral_terms = integrand.as_ordered_terms()\n",
    "        integrals = [sp.Integral(term, symbol) for term in integral_terms]\n",
    "        old_integral = integral\n",
    "        integral = sp.Add(*integrals)\n",
    "        tokenizable_steps.append((old_integral, old_integral, (steps.__class__.__name__, ), integral))\n",
    "\n",
    "        substeps = steps.substeps\n",
    "        for i, substep in enumerate(substeps):\n",
    "            decomposed_substep = decompose_steps(integral_terms[i], symbol, substep)\n",
    "            for element in decomposed_substep:\n",
    "                e_expr, e_subexpr, e_rule, e_res = element\n",
    "                old_integral = integral\n",
    "                integrals[i] = e_res\n",
    "                integral = sp.Add(*integrals)       \n",
    "                tokenizable_steps.append((old_integral, e_subexpr, e_rule, integral))  \n",
    "        \n",
    "\n",
    "    if isinstance(steps, ConstantTimesRule):\n",
    "        integrand = steps.integrand\n",
    "        symbol = steps.variable\n",
    "        constant = steps.constant\n",
    "        other = steps.other\n",
    "        old_integral = integral\n",
    "        integral = constant*sp.Integral(other, symbol)\n",
    "        tokenizable_steps.append((old_integral, old_integral, (steps.__class__.__name__, ), integral))\n",
    "\n",
    "        substep = steps.substep\n",
    "        decomposed_substep = decompose_steps(other, symbol, substep)\n",
    "        for element in decomposed_substep:\n",
    "            e_expr, e_subexpr, e_rule, e_res = element\n",
    "            old_integral = integral\n",
    "            integral = constant*e_res\n",
    "            tokenizable_steps.append((old_integral, e_subexpr, e_rule, integral))\n",
    "\n",
    "    if isinstance(steps, URule):\n",
    "        u_var = steps.u_var\n",
    "        u_func = steps.u_func\n",
    "\n",
    "        old_integral = integral\n",
    "        substep = steps.substep\n",
    "        integral = sp.Integral(substep.integrand, u_var)\n",
    "\n",
    "        tokenizable_steps.append((old_integral, old_integral, (steps.__class__.__name__, u_var, u_func), integral))\n",
    "        \n",
    "        decomposed_substep = decompose_steps(substep.integrand, u_var, substep)\n",
    "        tokenizable_steps += decomposed_substep\n",
    "\n",
    "    if isinstance(steps, PartsRule):\n",
    "        u = steps.u\n",
    "        dv = steps.dv\n",
    "        v_step = steps.v_step\n",
    "        second_step = steps.second_step\n",
    "        symbol = steps.variable\n",
    "\n",
    "        du = sp.diff(u, symbol)\n",
    "        old_integral = integral\n",
    "        \n",
    "        if isinstance(v_step, SIMPLE_STEPS):\n",
    "\n",
    "            v = v_step.eval()\n",
    "\n",
    "            integral_part = sp.Integral(v*du, symbol)\n",
    "            integral = u*v - integral_part\n",
    "\n",
    "            tokenizable_steps.append((old_integral, old_integral, (steps.__class__.__name__, u, dv, v_step.__class__.__name__), integral))\n",
    "            \n",
    "            decomposed_next_steps = decompose_steps(v*du, symbol, second_step)\n",
    "            for element in decomposed_next_steps:\n",
    "                e_expr, e_subexpr, e_rule, e_res = element\n",
    "                old_integral = integral\n",
    "                integral = u*v - e_res\n",
    "                tokenizable_steps.append((old_integral, e_subexpr, e_rule, integral))\n",
    "        \n",
    "        else:\n",
    "\n",
    "            v = sp.Integral(dv, symbol)\n",
    "            integral_part = sp.Integral(v*du, symbol)\n",
    "            integral = u*v - integral_part\n",
    "\n",
    "            tokenizable_steps.append((old_integral, old_integral, (steps.__class__.__name__, u, dv), integral))\n",
    "\n",
    "            decomposed_v_step = decompose_steps(dv, symbol, v_step)\n",
    "\n",
    "            for element in decomposed_v_step:\n",
    "                e_expr, e_subexpr, e_rule, e_res = element\n",
    "                old_integral = integral\n",
    "                integral = u*e_res - sp.Integral(e_res*du, symbol)\n",
    "                tokenizable_steps.append((old_integral, e_subexpr, e_rule, integral))\n",
    "\n",
    "            v = v_step.eval()\n",
    "\n",
    "            decomposed_next_steps = decompose_steps(v*du, symbol, second_step)\n",
    "            for element in decomposed_next_steps:\n",
    "                e_expr, e_subexpr, e_rule, e_res = element\n",
    "                old_integral = integral\n",
    "                integral = u*v - e_res\n",
    "                tokenizable_steps.append((old_integral, e_subexpr, e_rule, integral))\n",
    "\n",
    "\n",
    "    if isinstance(steps, AlternativeRule):\n",
    "        for alternative in steps.alternatives:\n",
    "            decomposed_alternative = decompose_steps(expression, symbol, alternative)\n",
    "            if None not in decomposed_alternative:\n",
    "                tokenizable_steps += decomposed_alternative\n",
    "        \n",
    "\n",
    "    return tokenizable_steps\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(Integral(acos(x), x), Integral(acos(x), x), ('PartsRule', acos(x), 1, 'ConstantRule'), x*acos(x) - Integral(-x/sqrt(1 - x**2), x))\n",
      "(x*acos(x) - Integral(-x/sqrt(1 - x**2), x), Integral(-x/sqrt(1 - x**2), x), ('ConstantTimesRule',), x*acos(x) + Integral(x/sqrt(1 - x**2), x))\n",
      "(x*acos(x) + Integral(x/sqrt(1 - x**2), x), Integral(x/sqrt(1 - x**2), x), ('ConstantTimesRule',), x*acos(x) - Integral(-2*x/sqrt(1 - x**2), x)/2)\n",
      "(x*acos(x) - Integral(-2*x/sqrt(1 - x**2), x)/2, Integral(-2*x/sqrt(1 - x**2), x), ('URule', _u, 1 - x**2), x*acos(x) - Integral(1/sqrt(_u), _u)/2)\n",
      "(x*acos(x) - Integral(1/sqrt(_u), _u)/2, Integral(1/sqrt(_u), _u), 'PowerRule', -sqrt(_u) + x*acos(x))\n"
     ]
    }
   ],
   "source": [
    "for step in decompose_steps(sp.acos(x) , x):\n",
    "    print(step)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "None\n"
     ]
    }
   ],
   "source": [
    "for step in decompose_steps(sp.acos(sp.sin(x)), x):\n",
    "    print(step)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ConstantTimesRule(integrand=2*x*cos(3*x - 2), variable=x, constant=2, other=x*cos(3*x - 2), substep=PartsRule(integrand=x*cos(3*x - 2), variable=x, u=x, dv=cos(3*x - 2), v_step=URule(integrand=cos(3*x - 2), variable=x, u_var=_u, u_func=3*x - 2, substep=ConstantTimesRule(integrand=cos(_u)/3, variable=_u, constant=1/3, other=cos(_u), substep=CosRule(integrand=cos(_u), variable=_u))), second_step=ConstantTimesRule(integrand=sin(3*x - 2)/3, variable=x, constant=1/3, other=sin(3*x - 2), substep=URule(integrand=sin(3*x - 2), variable=x, u_var=_u, u_func=3*x - 2, substep=ConstantTimesRule(integrand=sin(_u)/3, variable=_u, constant=1/3, other=sin(_u), substep=SinRule(integrand=sin(_u), variable=_u))))))"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "expr = sp.sympify(\"2*x*cos(3*x - 2)\")\n",
    "integral_steps(expr, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reading data from sample_data/prim_bwd_sample.train\n",
      "Number of expressions in data: 50000\n",
      "Returning 50000 expressions and integrals.\n",
      "Reading data from sample_data/prim_ibp_sample.train\n",
      "Number of expressions in data: 50000\n",
      "Returning 50000 expressions and integrals.\n",
      "Reading data from sample_data/prim_fwd_sample.train\n",
      "Number of expressions in data: 50000\n",
      "Returning 50000 expressions and integrals.\n"
     ]
    }
   ],
   "source": [
    "from utils import data_len, get_random_expressions\n",
    "import io\n",
    "\n",
    "DATASETS = ['prim_bwd', 'prim_ibp', 'prim_fwd']\n",
    "\n",
    "\n",
    "for dataset in DATASETS:\n",
    "    path = f'sample_data/{dataset}_sample.train'\n",
    "    expressions, integrals = get_random_expressions(path)\n",
    "    expressions = [sp.sympify(expr) for expr in expressions]\n",
    "\n",
    "    x = sp.Symbol('x')\n",
    "    \n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "None\n",
      "PartsRule(integrand=x*cos(3*x - 2), variable=x, u=x, dv=cos(3*x - 2), v_step=URule(integrand=cos(3*x - 2), variable=x, u_var=_u, u_func=3*x - 2, substep=ConstantTimesRule(integrand=cos(_u)/3, variable=_u, constant=1/3, other=cos(_u), substep=CosRule(integrand=cos(_u), variable=_u))), second_step=ConstantTimesRule(integrand=sin(3*x - 2)/3, variable=x, constant=1/3, other=sin(3*x - 2), substep=URule(integrand=sin(3*x - 2), variable=x, u_var=_u, u_func=3*x - 2, substep=ConstantTimesRule(integrand=sin(_u)/3, variable=_u, constant=1/3, other=sin(_u), substep=SinRule(integrand=sin(_u), variable=_u)))))\n"
     ]
    },
    {
     "ename": "TypeError",
     "evalue": "cannot unpack non-iterable NoneType object",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[1;32m/Users/mert/Desktop/integrator/steps.ipynb Cell 8\u001b[0m line \u001b[0;36m2\n\u001b[1;32m      <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=0'>1</a>\u001b[0m expr \u001b[39m=\u001b[39m sp\u001b[39m.\u001b[39msympify(\u001b[39m\"\u001b[39m\u001b[39m2*x*cos(3*x - 2)\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[0;32m----> <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=1'>2</a>\u001b[0m decompose_steps(expr, x)\n",
      "\u001b[1;32m/Users/mert/Desktop/integrator/steps.ipynb Cell 8\u001b[0m line \u001b[0;36m6\n\u001b[1;32m     <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=62'>63</a>\u001b[0m decomposed_substep \u001b[39m=\u001b[39m decompose_steps(other, symbol, substep)\n\u001b[1;32m     <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=63'>64</a>\u001b[0m \u001b[39mfor\u001b[39;00m element \u001b[39min\u001b[39;00m decomposed_substep:\n\u001b[0;32m---> <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=64'>65</a>\u001b[0m     e_expr, e_subexpr, e_rule, e_res \u001b[39m=\u001b[39m element\n\u001b[1;32m     <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=65'>66</a>\u001b[0m     old_integral \u001b[39m=\u001b[39m integral\n\u001b[1;32m     <a href='vscode-notebook-cell:/Users/mert/Desktop/integrator/steps.ipynb#X35sZmlsZQ%3D%3D?line=66'>67</a>\u001b[0m     integral \u001b[39m=\u001b[39m constant\u001b[39m*\u001b[39me_res\n",
      "\u001b[0;31mTypeError\u001b[0m: cannot unpack non-iterable NoneType object"
     ]
    }
   ],
   "source": [
    "expr = sp.sympify(\"2*x*cos(3*x - 2)\")\n",
    "decompose_steps(expr, x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'8*x*(log(x) + 1)*tan(2)*tanh(1)'"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "str(expr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "DATASET = 'prim_ibp'\n",
    "directory = f'decomposed_dataset/{DATASET}/'\n",
    "files = os.listdir(directory)\n",
    "false_count = 0\n",
    "for file in files:\n",
    "    data_path = directory + file\n",
    "    steps = get_steps(data_path)\n",
    "    for data in steps:\n",
    "        expr, subexpr, rule, result = data\n",
    "        expr = e.seq_to_sp(expr.split())\n",
    "        subexpr = e.seq_to_sp(subexpr.split())\n",
    "        print(result)\n",
    "        result = e.seq_to_sp(result.split())\n",
    "\n",
    "\n",
    "        rule = rule.split('\\t')\n",
    "        for i, r in enumerate(rule):\n",
    "            if i >= 1:\n",
    "                rule[i] = e.seq_to_sp(r.split())\n",
    "        \n",
    "        # print the steps\n",
    "        ''''''\n",
    "        logging.info(f'Expression: {expr}')\n",
    "        logging.info(f'Subexpression: {subexpr}')\n",
    "        logging.info(f'Rule: {rule}')\n",
    "        logging.info(f'Result: {result}')\n",
    "        logging.info('\\n')\n",
    "        ''''''\n",
    "\n",
    "        \n",
    "    break\n",
    "\n",
    "\n",
    "        #raise Exception\n"
   ]
  }
 ],
 "metadata": {
  "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.19"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
