Last modified: Jan 05, 2025 By Alexander Williams

Integrate Functions with SciPy: A Beginner's Guide

SciPy is a powerful Python library for scientific computing. It provides tools for integration, optimization, and more. In this guide, we'll focus on integrating functions using SciPy.

What is SciPy Integration?

SciPy's integration module, scipy.integrate, offers several methods to perform numerical integration. These methods help you compute the area under a curve or solve differential equations.

If you're new to SciPy, you might want to check out our guide on how to install SciPy in Python.

Basic Integration with SciPy

The simplest way to integrate a function is using the quad function. This function performs definite integration over a specified interval.

Here's an example:


from scipy.integrate import quad

# Define the function to integrate
def f(x):
    return x**2

# Perform the integration
result, error = quad(f, 0, 1)

print("Result:", result)
print("Error:", error)

In this example, we integrate the function f(x) = x^2 from 0 to 1. The quad function returns the result and an estimate of the error.


Result: 0.33333333333333337
Error: 3.700743415417189e-15

The result is approximately 1/3, which is the exact value of the integral. The error is very small, indicating high accuracy.

Integrating with Limits

Sometimes, you may need to integrate a function with infinite limits. SciPy's quad function can handle this as well.

Here's an example:


from scipy.integrate import quad
import numpy as np

# Define the function to integrate
def f(x):
    return np.exp(-x**2)

# Perform the integration from -infinity to +infinity
result, error = quad(f, -np.inf, np.inf)

print("Result:", result)
print("Error:", error)

This example integrates the Gaussian function over the entire real line. The result should be the square root of pi.


Result: 1.7724538509055159
Error: 1.4202636780944923e-08

The result is approximately 1.77245, which is the square root of pi. The error is again very small.

Solving Differential Equations

SciPy can also solve ordinary differential equations (ODEs). The solve_ivp function is commonly used for this purpose.

Here's an example:


from scipy.integrate import solve_ivp

# Define the ODE
def dydt(t, y):
    return -2 * y

# Initial condition
y0 = [1]

# Solve the ODE
sol = solve_ivp(dydt, [0, 5], y0, t_eval=[0, 1, 2, 3, 4, 5])

print("Time:", sol.t)
print("Solution:", sol.y[0])

This example solves the ODE dy/dt = -2y with the initial condition y(0) = 1. The solution is evaluated at specific time points.


Time: [0. 1. 2. 3. 4. 5.]
Solution: [1.         0.13533528 0.01831564 0.00247875 0.00033546 0.0000454]

The solution decays exponentially, as expected. The values at each time point are printed.

Conclusion

SciPy's integration tools are powerful and easy to use. Whether you're integrating simple functions or solving complex differential equations, SciPy has you covered.

For more advanced topics, check out our guides on finding eigenvalues and eigenvectors and solving linear equations with SciPy.

If you encounter any issues, such as the ModuleNotFoundError: No module named 'scipy', our troubleshooting guide can help.

Start integrating with SciPy today and unlock the full potential of scientific computing in Python!