SymPy-통합

SymPy 패키지에는 통합 모듈이 포함되어 있습니다. 그것은 식의 정적분과 부정적분을 계산하는 방법을 구현합니다. integration () 메서드는 정적분과 부정적분을 모두 계산하는 데 사용됩니다. 부정적분 또는 원시적 분을 계산하려면 식 뒤에 변수를 전달하면됩니다.

예를 들면-

integrate(f, x)

정적분을 계산하려면 다음과 같이 인수를 전달하십시오.

(integration_variable, lower_limit, upper_limit)
>>> from sympy import * 
>>> x,y = symbols('x y') 
>>> expr=x**2 + x + 1 
>>> integrate(expr, x)

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$\frac{x^3}{3} + \frac{x^2}{2} + x$

>>> expr=sin(x)*tan(x) 
>>> expr 
>>> integrate(expr,x)

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$-\frac{\log(\sin(x) - 1)}{2} + \frac{\log(\sin(x) + 1)}{2} - \sin(x)$

정적분의 예는 다음과 같습니다.

>>> expr=exp(-x**2) 
>>> integrate(expr,(x,0,oo) )

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$\frac{\sqrt\pi}{2}$

다중 적분을 수행하기 위해 여러 제한 튜플을 전달할 수 있습니다. 아래에 예가 나와 있습니다.

>>> expr=exp(-x**2 - y**2)
>>> integrate(expr,(x,0,oo),(y,0,oo))

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$\frac{\pi}{4}$

Doit () 메서드를 호출하여 평가할 수있는 Integral 객체를 사용하여 평가되지 않은 적분을 만들 수 있습니다.

>>> expr = Integral(log(x)**2, x) 
>>> expr

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$\int \mathrm\log(x)^2 \mathrm{d}x$

>>> expr.doit()

위의 코드 스 니펫은 아래 표현식에 해당하는 출력을 제공합니다.

$x\log(x)^2 - 2xlog(x) + 2x$

적분 변환

SymPy는 다음과 같이 다양한 유형의 적분 변환을 지원합니다.

  • laplace_transform
  • fourier_transform
  • sine_transform
  • cosine_transform
  • hankel_transform

이러한 함수는 sympy.integrals.transforms 모듈에 정의되어 있습니다. 다음 예제는 푸리에 변환과 라플라스 변환을 각각 계산합니다.

Example 1

>>> from sympy import fourier_transform, exp 
>>> from sympy.abc import x, k 
>>> expr=exp(-x**2) 
>>> fourier_transform(expr, x, k)

파이썬 셸에서 위의 명령을 실행하면 다음과 같은 출력이 생성됩니다.

sqrt(pi)*exp(-pi**2*k**2)

이것은-

$\sqrt\pi * e^{\pi^2k^2}$

Example 2

>>> from sympy.integrals import laplace_transform 
>>> from sympy.abc import t, s, a 
>>> laplace_transform(t**a, t, s)

파이썬 셸에서 위의 명령을 실행하면 다음과 같은 출력이 생성됩니다.

(s**(-a)*gamma(a + 1)/s, 0, re(a) > -1)