In SymPy, is it possible to apply limits to an indefinite integral and evaluate it?
import sympy
from sympy.abc import theta
y = sympy.sin(theta)
Y_indef = sympy.Integral(y)
Y_def = sympy.Integral(y, (theta, 0, sympy.pi / 2))
Y_def.evalf()
produces a number.
I'm looking for something like Y_indef.evalf((theta, 0, sympy.pi/2))
to get the same answer.
I do not know of a direct way, however you can extract the information from Y_indef
in order to create a definite integral:
>>> indef = Integral(x)
>>> to_be_integrated, (free_var,) = indef.args
>>> definite = Integral(to_be_integrated, (free_var, 1, 2))
.args
is a general attribute containing anything needed to construct most SymPy objects.
Edit: To address the comments to the questions.
SymPy may succeed evaluating definite integral and at the same time fail to solve their indefinite version. This is due to the existence of additional algorithms to be applied to definite integrals.
Both definite and indefinite integrals are instances of the same class. The only difference is what they contain in their .args
. The need for different classes is not yet felt, given that SymPy mostly uses Integral
as a flag to say that it can not solve the integral (i.e. the integrate
function returns Integral
when all of the implemented algorithms fail).