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 удовлетворит большинство наших потребностей в численном интегрировании.