SciPy-통합
함수를 분석적으로 통합 할 수 없거나 분석적으로 통합하기가 매우 어려운 경우 일반적으로 수치 통합 방법으로 전환합니다. SciPy에는 수치 적분을 수행하기위한 여러 루틴이 있습니다. 그들 대부분은 같은 곳에서 발견됩니다scipy.integrate도서관. 다음 표는 일반적으로 사용되는 몇 가지 기능을 나열합니다.
Sr 번호 | 기능 및 설명 |
---|---|
1 | quad 단일 통합 |
2 | dblquad 이중 통합 |
삼 | tplquad 트리플 통합 |
4 | nquad n- 다중 통합 |
5 | fixed_quad 가우스 구적법, 차수 n |
6 | quadrature 공차에 대한 가우스 구적법 |
7 | romberg Romberg 통합 |
8 | trapz 사다리꼴 규칙 |
9 | cumtrapz 적분을 누적 계산하기위한 사다리꼴 규칙 |
10 | simps 심슨의 규칙 |
11 | romb Romberg 통합 |
12 | polyint 분석 다항식 통합 (NumPy) |
13 | poly1d 폴리 인트 (NumPy)를위한 도우미 기능 |
단일 적분
Quad 기능은 SciPy 통합 기능의 핵심입니다. 수치 적 통합은 때때로 호출됩니다.quadrature, 따라서 이름. 일반적으로 a에서 b까지 주어진 고정 범위 에 대해 함수 f (x) 의 단일 적분을 수행하기위한 기본 선택입니다 .
$$ \ int_ {a} ^ {b} f (x) dx $$
쿼드의 일반적인 형태는 다음과 같습니다. scipy.integrate.quad(f, a, b), 여기서 'f'는 통합 할 함수의 이름입니다. 반면 'a'와 'b'는 각각 하한과 상한입니다. 0과 1의 범위에 걸쳐 통합 된 가우스 함수의 예를 살펴 보겠습니다.
먼저 함수를 정의해야합니다. → $ f (x) = e ^ {-x ^ 2} $, 이것은 람다 식을 사용하여 수행 한 다음 해당 함수에 대해 쿼드 메서드를 호출 할 수 있습니다.
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 함수는 exp, sin 및 cos와 같은 단일 변수의 표준 미리 정의 된 NumPy 함수를 통합 할 수 있습니다.
다중 적분
이중 및 삼중 통합의 메커니즘이 기능으로 요약되었습니다. dblquad, tplquad 과 nquad. 이러한 함수는 각각 4 개 또는 6 개의 인수를 통합합니다. 모든 내부 적분의 한계는 함수로 정의되어야합니다.
이중 적분
일반적인 형태 dblquadscipy.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에는 n- 폴드 다중 통합을 수행하는 nquad와 다양한 통합 알고리즘을 구현하는 기타 루틴을 비롯한 여러 통합 루틴이 있습니다. 그러나 quad 및 dblquad는 수치 적분에 대한 대부분의 요구 사항을 충족합니다.