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, tplquadnquad. 이러한 함수는 각각 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는 수치 적분에 대한 대부분의 요구 사항을 충족합니다.