SciPy - интегрировать

Когда функция не может быть интегрирована аналитически или ее очень сложно интегрировать аналитически, обычно обращаются к методам численного интегрирования. SciPy имеет ряд процедур для выполнения численного интегрирования. Большинство из них находятся в одномscipy.integrateбиблиотека. В следующей таблице перечислены некоторые часто используемые функции.

Sr Нет. Описание функции
1

quad

Единая интеграция

2

dblquad

Двойная интеграция

3

tplquad

Тройная интеграция

4

nquad

n- кратная множественная интеграция

5

fixed_quad

Квадратура Гаусса, порядок n

6

quadrature

Квадратура Гаусса с допуском

7

romberg

Интеграция Ромберга

8

trapz

Трапецеидальная линейка

9

cumtrapz

Правило трапеции для кумулятивного вычисления интеграла

10

simps

Правило Симпсона

11

romb

Интеграция Ромберга

12

polyint

Аналитическое полиномиальное интегрирование (NumPy)

13

poly1d

Вспомогательная функция для polyint (NumPy)

Отдельные интегралы

Функция Quad - это рабочая лошадка функций интеграции SciPy. Численное интегрирование иногда называютquadrature, отсюда и название. Обычно это выбор по умолчанию для выполнения единичных интегралов функции f (x) в заданном фиксированном диапазоне от a до b.

$$ \ int_ {a} ^ {b} f (x) dx $$

Общий вид квадрата: scipy.integrate.quad(f, a, b), Где «f» - имя интегрируемой функции. Принимая во внимание, что «a» и «b» - это нижний и верхний пределы соответственно. Давайте посмотрим на пример функции Гаусса, интегрированной в диапазоне от 0 до 1.

Сначала нам нужно определить функцию → $ f (x) = e ^ {- x ^ 2} $, это можно сделать с помощью лямбда-выражения, а затем вызвать метод quad для этой функции.

import scipy.integrate
from numpy import exp
f= lambda x:exp(-x**2)
i = scipy.integrate.quad(f, 0, 1)
print i

Вышеупомянутая программа выдаст следующий результат.

(0.7468241328124271, 8.291413475940725e-15)

Функция quad возвращает два значения, в которых первое число - это значение интеграла, а второе значение - оценка абсолютной ошибки в значении интеграла.

Note- Поскольку quad требует функцию в качестве первого аргумента, мы не можем напрямую передать exp в качестве аргумента. Функция Quad принимает в качестве пределов положительную и отрицательную бесконечность. Функция Quad может интегрировать стандартные предопределенные функции NumPy одной переменной, такие как exp, sin и cos.

Кратные интегралы

Механика двойной и тройной интеграции объединена в функции dblquad, tplquad и nquad. Эти функции объединяют четыре или шесть аргументов соответственно. Пределы всех внутренних интегралов должны быть определены как функции.

Двойные интегралы

Общая форма dblquadэто scipy.integrate.dblquad (func, a, b, gfun, hfun). Где func - это имя интегрируемой функции, 'a' и 'b' - это нижний и верхний пределы переменной x соответственно, а gfun и hfun - имена функций, которые определяют нижний и верхний пределы. переменной y.

В качестве примера воспользуемся методом двойного интеграла.

$$ \ int_ {0} ^ {1/2} dy \ int_ {0} ^ {\ sqrt {1-4y ^ 2}} 16xy \: dx $$

Мы определяем функции f, g и h, используя лямбда-выражения. Обратите внимание, что даже если g и h являются константами, как они могут быть во многих случаях, они должны быть определены как функции, как мы сделали здесь для нижнего предела.

import scipy.integrate
from numpy import exp
from math import sqrt
f = lambda x, y : 16*x*y
g = lambda x : 0
h = lambda y : sqrt(1-4*y**2)
i = scipy.integrate.dblquad(f, 0, 0.5, g, h)
print i

Вышеупомянутая программа выдаст следующий результат.

(0.5, 1.7092350012594845e-14)

В дополнение к процедурам, описанным выше, scipy.integrate имеет ряд других процедур интеграции, включая nquad, который выполняет n-кратную множественную интеграцию, а также другие процедуры, реализующие различные алгоритмы интеграции. Однако quad и dblquad удовлетворит большинство наших потребностей в численном интегрировании.