SymPy-퀵 가이드

SymPy는 기호 계산을 수행하기위한 Python 라이브러리입니다. 이것은computer algebra system(CAS)는 독립 실행 형 응용 프로그램으로, 다른 응용 프로그램에 대한 라이브러리로 사용할 수 있습니다. 라이브 세션은https://live.sympy.org/. 순수한 Python 라이브러리이므로 대화 형 모드 및 프로그래밍 응용 프로그램으로 사용할 수 있습니다. SymPy는 이제 과학적 Python 생태계에서 인기있는 상징 라이브러리가되었습니다.

SymPy는 기본 기호 산술, 미적분, 대수, 이산 수학, 양자 물리학 등의 분야에 적용 할 수있는 다양한 기능을 갖추고 있습니다. SymPy는 LaTeX, MathML 등 다양한 형식으로 결과를 형식화 할 수 있습니다. SymPy는 아래에 배포됩니다. 새로운 BSD 라이선스. 이끄는 개발자 팀Ondřej ČertíkAaron Meurer 2007 년에 SymPy의 첫 번째 버전을 발표했습니다. 현재 버전은 1.5.1입니다.

SymPy의 응용 분야 중 일부는 다음과 같습니다.

  • Polynomials
  • Calculus
  • 이산 수학
  • Matrices
  • Geometry
  • Plotting
  • Physics
  • Statistics
  • Combinatorics

SymPy에는 다음과 같은 중요한 필수 라이브러리가 있습니다. mpmath. 임의의 정밀도로 실제 및 복잡한 부동 소수점 산술을위한 Python 라이브러리입니다. 그러나 Python의 패키지 설치 프로그램 PIP는 SymPy가 다음과 같이 설치 될 때 자동으로 설치합니다.

pip install sympy

Anaconda, Enthought Canopy 등과 같은 다른 Python 배포판에는 이미 SymPy가 번들로 포함되어있을 수 있습니다. 확인하려면 Python 프롬프트에 다음을 입력하십시오.

>>> import sympy
>>> sympy.__version__

그리고 당신은 sympy의 현재 버전으로 아래 출력을 얻습니다-

'1.5.1'

SymPy 패키지의 소스 코드는 https://github.com/sympy/sympy.

기호 계산은 수학적 표현 및 기타 수학적 개체를 조작하기위한 알고리즘 개발을 의미합니다. 기호 계산은 수학 기호를 사용하여 수학 표현을 풀기 위해 컴퓨터 과학과 수학을 통합합니다. SymPy와 같은 CAS (Computer Algebra System)는 전통적인 수동 방법에서 사용되는 것과 동일한 기호를 사용하여 대수식을 정확히 (대략적이지 않음) 평가합니다. 예를 들어, 아래와 같이 파이썬의 수학 모듈을 사용하여 숫자의 제곱근을 계산합니다.

>>> import math 
>>> print (math.sqrt(25), math.sqrt(7))

위 코드 스 니펫의 출력은 다음과 같습니다.

5.0 2.6457513110645907

보시다시피, 7의 제곱근은 대략적으로 계산됩니다. 그러나 SymPy에서 완전 제곱이 아닌 숫자의 제곱근은 기본적으로 다음과 같이 평가되지 않은 상태로 남아 있습니다.

>>> import sympy 
>>> print (sympy.sqrt(7))

위 코드 스 니펫의 출력은 다음과 같습니다.

sqrt(7)

아래 코드 스 니펫을 사용하여 표현의 결과를 상징적으로 단순화하고 표시 할 수 있습니다.

>>> import math
>>> print (math.sqrt(12))

위 코드 스 니펫의 출력은 다음과 같습니다.

3.4641016151377544

sympy를 사용하여 동일하게 실행하려면 아래 코드 스 니펫을 사용해야합니다.

##sympy output 
>>> print (sympy.sqrt(12))

이에 대한 출력은 다음과 같습니다.

2*sqrt(3)

Jupyter 노트북에서 실행되는 SymPy 코드는 MathJax 라이브러리를 사용하여 수학 기호를 LatEx 형식으로 렌더링합니다. 아래 코드 스 니펫에 나와 있습니다.

>>> from sympy import * 
>>> x=Symbol ('x') 
>>> expr = integrate(x**x, x) 
>>> expr

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

Integral(x**x, x)

다음과 같습니다.

$\int \mathrm{x}^{x}\,\mathrm{d}x$

완전하지 않은 정사각형의 제곱근은 다음과 같이 전통적인 기호를 사용하여 Latex로 나타낼 수 있습니다.

>>> from sympy import * 
>>> x=7 
>>> sqrt(x)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\sqrt7$

SymPy와 같은 기호 계산 시스템은 모든 종류의 계산 (예 : 미분, 적분 및 한계, 방정식 풀기, 행렬 작업)을 기호 적으로 수행합니다. SymPy 패키지에는 플로팅, 인쇄 (예 : LATEX), 물리, 통계, 조합, 수 이론, 기하학, 논리 등을 지원하는 다양한 모듈이 있습니다.

SymPy 패키지의 핵심 모듈에는 원자 번호를 나타내는 Number 클래스가 포함되어 있습니다. 이 클래스에는 Float 및 Rational 클래스의 두 개의 하위 클래스가 있습니다. Rational 클래스는 Integer 클래스에 의해 더욱 확장됩니다.

Float 클래스는 임의 정밀도의 부동 소수점 수를 나타냅니다.

>>> from sympy import Float 
>>> Float(6.32)

위 코드 스 니펫의 출력은 다음과 같습니다.

6.32

SymPy는 정수 또는 문자열을 부동으로 변환 할 수 있습니다.

>>> Float(10)

10.0

Float('1.33E5')# scientific notation

133000.0

float로 변환하는 동안 아래에 주어진 것처럼 정밀도를 위해 자릿수를 지정할 수도 있습니다.

>>> Float(1.33333,2)

위 코드 스 니펫의 출력은 다음과 같습니다.

1.3

숫자 (p / q) 표현은 q가 0이 아닌 숫자 인 Rational 클래스의 객체로 표시됩니다.

>>> Rational(3/4)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\frac{3}{4}$

부동 소수점 숫자가 Rational () 생성자에 전달되면 이진 표현의 기본 값을 리턴합니다.

>>> Rational(0.2)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\frac{3602879701896397}{18014398509481984}$

더 간단한 표현을 위해 분모 제한을 지정하십시오.

>>> Rational(0.2).limit_denominator(100)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\frac{1}{5}$

문자열이 Rational () 생성자에 전달되면 합리적인 수의 임의 정밀도가 리턴됩니다.

>>> Rational("3.65")

위 코드 스 니펫의 출력은 다음과 같습니다.

$\frac{73}{20}$

두 개의 숫자 인수가 전달되면 유리한 객체를 얻을 수도 있습니다. 분자 및 분모 부분을 속성으로 사용할 수 있습니다.

>>> a=Rational(3,5) 
>>> print (a) 
>>> print ("numerator:{}, denominator:{}".format(a.p, a.q))

위 코드 스 니펫의 출력은 다음과 같습니다.

3/5

numerator:3, denominator:5

>>> a

위 코드 스 니펫의 출력은 다음과 같습니다.

$\frac{3}{5}$

SymPy의 정수 클래스는 모든 크기의 정수를 나타냅니다. 생성자는 Float 또는 Rational 숫자를 허용 할 수 있지만 소수 부분은 버립니다.

>>> Integer(10)

위 코드 스 니펫의 출력은 다음과 같습니다.

10

>>> Integer(3.4)

위 코드 스 니펫의 출력은 다음과 같습니다.

3

>>> Integer(2/7)

위 코드 스 니펫의 출력은 다음과 같습니다.

0

SymPy는 RealNumberFloat의 별칭 역할을하는 클래스. SymPy는 또한 Zero와 One을 아래와 같이 S.Zero와 S.One으로 접근 가능한 싱글 톤 클래스로 정의합니다.

>>> S.Zero

출력은 다음과 같습니다.

0

>>> S.One

출력은 다음과 같습니다.

1

기타 미리 정의 된 Singleton 숫자 객체는 Half, NaN, Infinity 및 ImaginaryUnit입니다.

>>> from sympy import S 
>>> print (S.Half)

출력은 다음과 같습니다.

½

>>> print (S.NaN)

출력은 다음과 같습니다.

nan

Infinity는 oo 기호 객체 또는 S.Infinity로 사용할 수 있습니다.

>>> from sympy import oo 
>>> oo

위 코드 스 니펫의 출력은 다음과 같습니다.

$\infty$

>>> S.Infinity

위 코드 스 니펫의 출력은 다음과 같습니다.

$\infty$

ImaginaryUnit 번호는 I 기호로 가져 오거나 S.ImaginaryUnit으로 액세스 할 수 있으며 -1의 제곱근을 나타냅니다.

>>> from sympy import I 
>>> I

위의 코드 조각을 실행하면 다음과 같은 출력이 나타납니다.

i

>>> S.ImaginaryUnit

위 스 니펫의 출력은 다음과 같습니다.

i

>>> from sympy import sqrt 
>>> i=sqrt(-1) 
>>> i*i

위의 코드 조각을 실행하면 다음과 같은 출력이 나타납니다.

-1

SymbolsymPy 라이브러리에서 가장 중요한 클래스입니다. 앞서 언급했듯이 기호 계산은 기호로 수행됩니다. SymPy 변수는 Symbols 클래스의 객체입니다.

Symbol () 함수의 인수는 변수에 할당 할 수있는 기호를 포함하는 문자열입니다.

>>> from sympy import Symbol 
>>> x=Symbol('x') 
>>> y=Symbol('y') 
>>> expr=x**2+y**2 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^2 + y^2$

기호는 두 개 이상의 알파벳 일 수 있습니다.

>>> s=Symbol('side') 
>>> s**3

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$side^3$

SymPy는 또한 Symbols()한 번에 여러 심볼을 정의 할 수있는 기능입니다. 문자열에는 쉼표 또는 공백으로 구분 된 변수 이름이 포함됩니다.

>>> from sympy import symbols 
>>> x,y,z=symbols("x,y,z")

SymPy의 abc 모듈에서 모든 라틴 및 그리스 알파벳은 기호로 정의됩니다. 따라서 Symbol 객체를 인스턴스화하는 대신이 방법이 편리합니다.

>>> from sympy.abc import x,y,z

그러나 이름 C, O, S, I, N, EQ미리 정의 된 기호입니다. 또한 알파벳이 두 개 이상인 심볼은 abc 모듈에 정의되어 있지 않으므로 위와 같이 Symbol 객체를 사용해야합니다. abc 모듈은 기본 SymPy 네임 스페이스에서 정의를 감지 할 수있는 특수 이름을 정의합니다. clash1에는 단일 문자가 포함되고 clash2에는 다중 문자 충돌 기호가 있습니다.

>>> from sympy.abc import _clash1, _clash2 
>>> _clash1

위 스 니펫의 출력은 다음과 같습니다.

{'C': C, 'O': O, 'Q': Q, 'N': N, 'I': I, 'E': E, 'S': S}

>>> _clash2

위 스 니펫의 출력은 다음과 같습니다.

{'beta': beta, 'zeta': zeta, 'gamma': gamma, 'pi': pi}

인덱싱 된 기호는 range () 함수와 유사한 구문을 사용하여 정의 할 수 있습니다. 범위는 콜론으로 표시됩니다. 범위 유형은 콜론 오른쪽에있는 문자로 결정됩니다. itr이 숫자이면 왼쪽의 모든 연속 숫자가 음이 아닌 시작 값으로 간주됩니다. 오른쪽의 모든 연속 숫자는 종료 값보다 1 큰 것으로 간주됩니다.

>>> from sympy import symbols 
>>> symbols('a:5')

위 스 니펫의 출력은 다음과 같습니다.

(a0, a1, a2, a3, a4)

>>> symbols('mark(1:4)')

위 스 니펫의 출력은 다음과 같습니다.

(mark1, mark2, mark3)

수학적 표현에서 수행되는 가장 기본적인 연산 중 하나는 대체입니다. SymPy의 subs () 함수는 첫 번째 매개 변수의 모든 발생을 두 번째로 바꿉니다.

>>> from sympy.abc import x,a 
>>> expr=sin(x)*sin(x)+cos(x)*cos(x) 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\sin^2(x)+\cos^2(x)$

>>> expr.subs(x,a)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\sin^2(a)+\cos^2(a)$

이 함수는 특정 표현식을 평가하려는 경우 유용합니다. 예를 들어 a를 5로 대체하여 다음 식의 값을 계산하려고합니다.

>>> expr=a*a+2*a+5 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$a^2 + 2a + 5$

expr.subs(a,5)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

40

>>> from sympy.abc import x 
>>> from sympy import sin, pi 
>>> expr=sin(x) 
>>> expr1=expr.subs(x,pi) 
>>> expr1

위의 코드 조각은 다음과 같은 출력을 제공합니다.

0

이 함수는 하위 식을 다른 하위 식으로 바꾸는데도 사용됩니다. 다음 예에서 b는 a + b로 대체됩니다.

>>> from sympy.abc import a,b 
>>> expr=(a+b)**2 
>>> expr1=expr.subs(b,a+b) 
>>> expr1

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$(2a + b)^2$

sympify () 함수는 임의의 표현식을 SymPy 표현식으로 사용할 수 있도록 변환하는 데 사용됩니다. 정수 객체와 같은 일반적인 Python 객체는 SymPy에서 변환됩니다. 정수 등의 문자열도 SymPy 표현식으로 변환됩니다.

>>> expr="x**2+3*x+2" 
>>> expr1=sympify(expr) 
>>> expr1 
>>> expr1.subs(x,2)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

12

모든 Python 개체는 SymPy 개체에서 변환 할 수 있습니다. 그러나 변환은 내부적으로 eval () 함수를 사용하기 때문에 unsanitized 표현식을 사용해서는 안되며, 그렇지 않으면 SympifyError가 발생합니다.

>>> sympify("x***2")
---------------------------------------------------------------------------

SympifyError : 'x *** 2'표현식의 Sympify가 예외 발생으로 인해 실패했습니다.

sympify () 함수는 다음 인수를 사용합니다. * strict : 기본값은 False입니다. True로 설정하면 명시 적 변환이 정의 된 유형 만 변환됩니다. 그렇지 않으면 SympifyError가 발생합니다. * 평가 : False로 설정하면 산술 및 연산자가 식을 평가하지 않고 동등한 SymPy로 변환됩니다.

>>> sympify("10/5+4/2")

위의 코드 조각은 다음과 같은 출력을 제공합니다.

4

>>> sympify("10/5+4/2", evaluate=False)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

$\frac{10}{5}+\frac{4}{2}$

이 함수는 최대 100 자리까지 주어진 부동 소수점 정밀도까지 주어진 숫자 표현식을 평가합니다. 이 함수는 또한 기호에 대한 숫자 값의 사전 개체 인 subs 매개 변수를 사용합니다. 다음 표현을 고려하십시오

>>> from sympy.abc import r 
>>> expr=pi*r**2 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\Pi{r^2}$

r을 5로 대체하여 evalf () 함수를 사용하여 위의 표현식을 평가하려면

>>> expr.evalf(subs={r:5})

위의 코드 조각은 다음과 같은 출력을 제공합니다.

78.5398163397448

기본적으로 부동 소수점 정밀도는 최대 15 자리이며 최대 100 개의 숫자로 재정의 할 수 있습니다. 다음 표현식은 최대 20 자리의 정밀도로 평가됩니다.

>>> expr=a/b 
>>> expr.evalf(20, subs={a:100, b:3})

위의 코드 조각은 다음과 같은 출력을 제공합니다.

33.333333333333333333

lambdify 함수는 SymPy 표현식을 Python 함수로 변환합니다. 넓은 범위의 값에 대해 표현식을 평가해야하는 경우 evalf () 함수는 효율적이지 않습니다. lambdify는 SymPy 이름을 주어진 숫자 라이브러리의 이름 (일반적으로 NumPy)으로 변환한다는 점을 제외하면 람다 함수처럼 작동합니다. 기본적으로 수학 표준 라이브러리의 구현에 대해 lambdify합니다.

>>> expr=1/sin(x) 
>>> f=lambdify(x, expr) 
>>> f(3.14)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

627.8831939138764

표현식에는 둘 이상의 변수가있을 수 있습니다. 이 경우 lambdify () 함수의 첫 번째 인수는 변수 목록이고 그 뒤에 평가할 표현식이옵니다.

>>> expr=a**2+b**2 
>>> f=lambdify([a,b],expr) 
>>> f(2,3)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

13

그러나 숫자 백엔드로 numpy 라이브러리를 활용하려면 lambdify () 함수에 대한 인수와 동일하게 정의해야합니다.

>>> f=lambdify([a,b],expr, "numpy")

위의 함수에서 두 개의 인수 a와 b에 대해 두 개의 numpy 배열을 사용합니다. numpy 배열의 경우 실행 시간이 상당히 빠릅니다.

>>> import numpy 
>>> l1=numpy.arange(1,6) 
>>> l2=numpy.arange(6,11) 
>>> f(l1,l2)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

array([ 37, 53, 73, 97, 125], dtype=int32)

부울 함수는 sympy.basic.booleanarg module. 표준 파이썬 연산자 & (And), |를 사용하여 부울 표현식을 작성할 수 있습니다. (Or), ~ (Not)뿐만 아니라 >> 및 <<. 부울 표현식은 SymPy의 핵심 모듈에 정의 된 기본 클래스에서 상속됩니다.

BooleanTrue 함수

이 함수는 핵심 Python에서와 마찬가지로 True와 동일합니다. S.true로 검색 할 수있는 싱글 톤을 반환합니다.

>>> from sympy import * 
>>> x=sympify(true) 
>>> x, S.true

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(진짜 진짜)

BooleanFalse 함수

마찬가지로이 함수는 Python의 Boolean False와 동일하며 S.false로 액세스 할 수 있습니다.

>>> from sympy import * 
>>> x=sympify(false) 
>>> x, S.false

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 거짓)

그리고 기능

논리 AND 함수는 두 인수를 평가하고 둘 중 하나가 False이면 False를 반환합니다. 이 함수는 & 연산자를 에뮬레이트합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import And 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=True 
>>> And(x,y), x"&"y

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(진짜 진짜)

>>> y=False 
>>> And(x,y), x"&"y

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 거짓)

또는 기능

이 함수는 두 개의 부울 인수를 평가하고 둘 중 하나가 True이면 True를 반환합니다. | 연산자는 편리하게 동작을 에뮬레이트합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Or 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False 
>>> Or(x,y), x|y

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(진짜 진짜)

>>> x=False 
>>> y=False 
>>> Or(x,y), x|y

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 거짓)

기능하지 않음

Logical Not 함수는 부울 인수를 부정합니다. 인수가 False이면 True를 반환하고 True이면 False를 반환합니다. ~ 연산자는 Not 함수와 유사한 작업을 수행합니다. 아래 예에 나와 있습니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Or, And, Not 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False 
>>> Not(x), Not(y)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 참)

>>> Not(And(x,y)), Not(Or(x,y))

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(허위 사실)

Xor 기능

논리 XOR (배타적 OR) 함수는 홀수 인수가 True이고 나머지가 False이면 True를 반환하고 짝수 인수가 True이고 나머지가 False이면 False를 반환합니다. ^ 연산자가 유사한 작업을 수행합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Xor 
>>> x,y=symbols('x y') 
>>> x=True 
>>> y=False

>>> Xor(x,y), x^y

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(진짜 진짜)

>>> a,b,c,d,e=symbols('a b c d e') 
>>> a,b,c,d,e=(True, False, True, True, False) 
>>> Xor(a,b,c,d,e)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

진실

위의 경우 세 개의 (홀수) 인수가 True이므로 Xor는 true를 반환합니다. 그러나 True 인수의 수가 짝수이면 아래와 같이 False가됩니다.

>>> a,b,c,d,e=(True, False, False, True, False) 
>>> Xor(a,b,c,d,e)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

그릇된

Nand 기능

이 함수는 논리 NAND 연산을 수행합니다. 인수를 평가하고 둘 중 하나가 False이면 True를 반환하고 모두 True이면 False를 반환합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Nand 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Nand(a,b,c), Nand(a,c)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(허위 사실)

기능 없음

이 함수는 논리 NOR 연산을 수행합니다. 인수를 평가하고 True이면 False를 반환하고 모두 False이면 True를 반환합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Nor 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Nor(a,b,c), Nor(a,c)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 거짓)

SymPy가 Xor에 대해 ^ 연산자를 제공하고 Not에 대해 ~를 제공하더라도 | For Or 및 & for And 함수는 편의상 Python에서 일반적인 사용은 비트 연산자와 같습니다. 따라서 피연산자가 정수이면 결과가 달라집니다.

동등한 기능

이 함수는 등가 관계를 반환합니다. Equivalent (A, B)는 A와 B가 모두 True이거나 둘 다 False 인 경우에만 True입니다. 모든 인수가 논리적으로 동일한 경우 함수는 True를 반환합니다. 그렇지 않으면 False를 반환합니다.

>>> from sympy import * 
>>> from sympy.logic.boolalg import Equivalent 
>>> a,b,c=symbols('a b c') 
>>> a,b,c=(True, False, True) 
>>> Equivalent(a,b), Equivalent(a,c)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 참)

ITE 기능

이 함수는 프로그래밍 언어에서 If then else 절로 작동합니다. ITE (A, B, C)는 A가 참이면 B의 결과를 평가하고 반환합니다. 그렇지 않으면 C의 결과를 반환합니다. 모든 인수는 부울이어야합니다.

>>> from sympy import * >>> from sympy.logic.boolalg import ITE >>> a,b,c=symbols('a b c') >>> a,b,c=(True, False, True) 
>>> ITE(a,b,c), ITE(a,c,b)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

(거짓, 참)

SymPy 패키지의 가정 모듈에는 표현식에 대한 정보를 추출하는 도구가 포함되어 있습니다. 모듈은이를 위해 ask () 함수를 정의합니다.

sympy.assumptions.ask(property)

다음 속성은 표현식에 대한 유용한 정보를 제공합니다.

algebraic(x)

대수적이 되려면 숫자가 유리 계수가있는 0이 아닌 다항 방정식의 근이어야합니다. √2는 √2가 x2 − 2 = 0의 해이기 때문에 대수적입니다.

complex(x)

복소수 술어. x가 복소수의 집합에 속하는 경우에만 참입니다.

composite(x)

ask (Q.composite (x))가 반환하는 복합 숫자 술어는 x가 양의 정수이고 1이 아닌 양의 제수와 숫자 자체가 하나 이상있는 경우에만 참입니다.

even, odd

ask ()는 x가 각각 짝수 세트와 홀수 세트에 있다는 사실을 반환합니다.

imaginary

이 속성은 허수 술어를 나타냅니다. x가 허수 단위 I를 곱한 실수로 쓸 수 있다면 참입니다.

integer

Q.integer (x)에 의해 반환 된이 속성은 x가 짝수 집합에 속하는 true를 반환합니다.

rational, irrational

Q.irrational (x)는 x가 정수 비율로 표현할 수없는 실수 인 경우에만 참입니다. 예를 들어, pi는 무리수입니다.

positive, negative

숫자가 양수인지 음수인지 확인하는 술어

zero, nonzero

숫자가 0인지 아닌지 확인하는 술어

>>> from sympy import * 
>>> x=Symbol('x') 
>>> x=10 
>>> ask(Q.algebraic(pi))
False
>>> ask(Q.complex(5-4*I)), ask( Q.complex(100))
(True, True)
>>> x,y=symbols("x y") 
>>> x,y=5,10 
>>> ask(Q.composite(x)), ask(Q.composite(y))
(False, True)
>>> ask(Q.even(x)), ask(Q.even(y))
(False, True)
>>> x,y= 2*I, 4+5*I 
>>> ask(Q.imaginary(x)), ask(Q.imaginary(y))
(True, False)
>>> x,y=5,10 
>>> ask(Q.even(x)), ask(Q.even(y)), ask(Q.odd(x)), ask(Q.odd(y))
(False, True, True, False)
>>> x,y=5,-5 
>>> ask(Q.positive(x)), ask(Q.negative(y)), ask(Q.positive(x)), ask(Q.negative(y))
(True, True, True, True)
>>> ask(Q.rational(pi)), ask(Q.irrational(S(2)/3))
(False, False)
>>> ask(Q.zero(oo)), ask(Q.nonzero(I))
(False, False)

Sympy는 수학적 표현을 단순화하는 강력한 능력을 가지고 있습니다. SymPy에는 다양한 단순화를 수행하는 많은 기능이 있습니다. simple ()이라는 일반 함수는 가장 단순한 형태의 표현식에 도달하려고 시도합니다.

단순화

이 함수는 sympy.simplify 모듈에 정의되어 있습니다. impl ()은 입력 표현식을 "단순"하게 만들기 위해 지능형 휴리스틱을 적용하려고합니다. 다음 코드는 표현을 단순화합니다.$sin^2(x)+cos^2(x)$.

>>> from sympy import * 
>>> x=Symbol('x')
>>> expr=sin(x)**2 + cos(x)**2 
>>> simplify(expr)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

1

넓히다

expand ()는 다항식 확장에 사용되는 SymPy에서 가장 일반적인 단순화 함수 중 하나입니다. 예를 들면-

>>> a,b=symbols('a b') 
>>> expand((a+b)**2)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$a^2 + 2ab + b^2$

>>> expand((a+b)*(a-b))

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$a^2 - b^2$

expand () 함수는 표현식을 더 작게 만드는 것이 아니라 더 크게 만듭니다. 일반적으로 이것이 사실이지만, 종종 expand ()를 호출하면 표현식이 더 작아집니다.

>>> expand((x + 1)*(x - 2) - (x - 1)*x)

위의 코드 조각은 다음과 같은 출력을 제공합니다.

-2

인자

이 함수는 다항식을 취하여 유리수에 대해 기약 할 수없는 요인으로 인수 분해합니다.

>>> x,y,z=symbols('x y z') 
>>> expr=(x**2*z + 4*x*y*z + 4*y**2*z) 
>>> factor(expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$z(x + 2y)^2$

>>> factor(x**2+2*x+1)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$(x + 1)^2$

factor () 함수는 expand ()와 반대입니다. factor ()에 의해 반환 된 각 요소는 축소 할 수 없습니다. factor_list () 함수는보다 구조화 된 출력을 반환합니다.

>>> expr=(x**2*z + 4*x*y*z + 4*y**2*z) 
>>> factor_list(expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

(1, [(z, 1), (x + 2*y, 2)])

수집

이 함수는 합리적 지수를 가진 거듭 제곱까지의 표현식 목록과 관련하여 표현식의 추가 항을 수집합니다.

>>> expr=x*y + x - 3 + 2*x**2 - z*x**2 + x**3 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^3 + x^2z + 2x^2 + xy + x - 3$

이 표현식에 대한 collect () 함수는 다음과 같습니다.

>>> collect(expr,x)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^3 + x^2(2 - z) + x(y + 1) - 3$

>>> expr=y**2*x + 4*x*y*z + 4*y**2*z+y**3+2*x*y 
>>> collect(expr,y)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$Y^3+Y^2(x+4z)+y(4xz+2x)$

취소

cancel () 함수는 합리적 함수를 취하여 표준 표준 형식 인 p / q에 넣습니다. 여기서 p와 q는 공통 인자가없는 확장 다항식입니다. p와 q의 선행 계수에는 분모가 없습니다. 즉, 정수입니다.

>>> expr1=x**2+2*x+1 
>>> expr2=x+1 
>>> cancel(expr1/expr2)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x+1$

>>> expr = 1/x + (3*x/2 - 2)/(x - 4) 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{\frac{3x}{2} - 2}{x - 4} + \frac{1}{x}$

>>> cancel(expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{3x^2 - 2x - 8}{2x^2 - 8}$

>>> expr=1/sin(x)**2 
>>> expr1=sin(x) 
>>> cancel(expr1*expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{1}{\sin(x)}$

Trigsimp

이 함수는 삼각 ID를 단순화하는 데 사용됩니다. 역삼 각 함수에 대한 명명 규칙은 함수 이름 앞에 a를 추가하는 것입니다. 예를 들어, 역 코사인 또는 아크 코사인은 acos ()라고합니다.

>>> from sympy import trigsimp, sin, cos 
>>> from sympy.abc import x, y
>>> expr = 2*sin(x)**2 + 2*cos(x)**2 
>>> trigsimp(expr)

2

trigsimp 함수는 휴리스틱을 사용하여 가장 적합한 삼각법 ID를 적용합니다.

파워 심프

이 함수는 거듭 제곱을 유사한 밑수 및 지수와 결합하여 주어진 표현을 줄입니다.

>>> expr=x**y*x**z*y**z 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^y x^z y^z$

>>> powsimp(expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^{y+z} y^z$

powsimp ()는 bases 만 결합하거나 combine = 'base'또는 combine = 'exp'를 변경하여 지수 만 결합 할 수 있습니다. 기본적으로 combine = 'all'은 둘 다 수행합니다. force가 True이면 가정을 확인하지 않고베이스가 결합됩니다.

>>> powsimp(expr, combine='base', force=True)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^y(xy)^z$

빗질하다

계승 및 이항식을 포함하는 조합 식은 combsimp () 함수를 사용하여 단순화 할 수 있습니다. SymPy는 factorial () 함수를 제공합니다.

>>> expr=factorial(x)/factorial(x - 3) 
>>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{x!}{(x - 3)!}$

위의 조합 식을 단순화하기 위해 다음과 같이 combsimp () 함수를 사용합니다.

>>> combsimp(expr)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x(x-2)(x-1)$

이항 (x, y)은 x 개의 고유 항목 집합에서 y 항목을 선택하는 방법의 수입니다. 또한 종종 xCy로 작성됩니다.

>>> binomial(x,y)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$(\frac{x}{y})$

>>> combsimp(binomial(x+1, y+1)/binomial(x, y))

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{x + 1}{y + 1}$

Logcombine

이 함수는 로그를 취하고 다음 규칙을 사용하여 결합합니다.

  • log (x) + log (y) == log (x * y) 둘 다 양수이면
  • a * log (x) == log (x ** a) x가 양수이고 a가 실수 인 경우
>>> logcombine(a*log(x) + log(y) - log(z))

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$a\log(x) + \log(y) - \log(z)$

이 함수의 force 매개 변수가 True로 설정되면 수량에 대한 가정이 이미 존재하지 않으면 위의 가정이 유지되는 것으로 간주됩니다.

>>> logcombine(a*log(x) + log(y) - log(z), force=True)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\log\frac{x^a y}{z}$

함수의 미분은 변수 중 하나에 대한 즉각적인 변화율입니다. 이것은 한 지점에서 함수에 대한 접선의 기울기를 찾는 것과 동일하며, SymPy 패키지에서 diff () 함수를 사용하여 변수 형태의 수학적 표현의 미분을 찾을 수 있습니다.

diff(expr, variable)
>>> from sympy import diff, sin, exp 
>>> from sympy.abc import x,y 
>>> expr=x*sin(x*x)+1 >>> expr

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x\sin(x^2) + 1$

>>> diff(expr,x)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$2x^2\cos(x^2) + \sin(x^2)$

>>> diff(exp(x**2),x)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

2xex2

여러 도함수를 사용하려면 미분하고 싶은만큼 변수를 전달하거나 변수 뒤에 숫자를 전달하십시오.

>>> diff(x**4,x,3)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$24x$

>>> for i in range(1,4): print (diff(x**4,x,i))

위의 코드 스 니펫은 아래 표현식을 제공합니다.

4*x**3

12*x**2

24*x

표현식의 diff () 메서드를 호출 할 수도 있습니다. diff () 함수와 유사하게 작동합니다.

>>> expr=x*sin(x*x)+1 
>>> expr.diff(x)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$2x^2\cos(x^2) + \sin(x^2)$

평가되지 않은 파생물은 Derivative 클래스를 사용하여 생성됩니다. diff () 함수와 동일한 구문을 가지고 있습니다. 평가되지 않은 도함수를 평가하려면 doit 방법을 사용하십시오.

>>> from sympy import Derivative 
>>> d=Derivative(expr) 
>>> d

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{d}{dx}(x\sin(x^2)+1)$

>>> d.doit()

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$2x^2\cos(x^2) + \sin(x^2)$

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)

수학에서 행렬은 숫자, 기호 또는 표현식의 2 차원 배열입니다. 행렬 조작 이론은 특정 규칙에 따라 행렬 객체에 대한 산술 연산을 수행하는 것을 다룹니다.

선형 변환은 행렬의 중요한 응용 프로그램 중 하나입니다. 특히 물리학과 관련된 많은 과학 분야는 매트릭스 관련 응용 프로그램을 사용합니다.

SymPy 패키지에는 매트릭스 처리를 다루는 매트릭스 모듈이 있습니다. 객체가 행렬을 나타내는 Matrix 클래스를 포함합니다.

Note: If you want to execute all the snippets in this chapter individually, you need to import the matrix module as shown below −

>>> from sympy.matrices import Matrix

Example

>>> from sympy.matrices import Matrix 
>>> m=Matrix([[1,2,3],[2,3,1]]) 
>>> m
$\displaystyle \left[\begin{matrix}1 & 2 & 3\\2 & 3 & 1\end{matrix}\right]$

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

[1 2 3 2 3 1]

매트릭스는 적절한 크기의 List 개체에서 만들어집니다. 지정된 수의 행과 열에 목록 항목을 배포하여 행렬을 얻을 수도 있습니다.

>>> M=Matrix(2,3,[10,40,30,2,6,9]) 
>>> M
$\displaystyle \left[\begin{matrix}10 & 40 & 30\\2 & 6 & 9\end{matrix}\right]$

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

[10 40 30 2 6 9]

매트릭스는 변경 가능한 객체입니다. matrices 모듈은 또한 불변 행렬을 얻기 위해 ImmutableMatrix 클래스를 제공합니다.

기본 조작

그만큼 shape Matrix 객체의 속성은 크기를 반환합니다.

>>> M.shape

위 코드의 출력은 다음과 같습니다.

(2,3)

row () 및 col () 메서드는 각각 지정된 수의 행 또는 열을 반환합니다.

>>> M.row(0)
$\displaystyle \left[\begin{matrix}10 & 40 & 30\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[10 40 30]

>>> M.col(1)
$\displaystyle \left[\begin{matrix}40\\6\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[40 6]

Python의 슬라이스 연산자를 사용하여 행 또는 열에 속하는 하나 이상의 항목을 가져옵니다.

>>> M.row(1)[1:3]
[6, 9]

Matrix 클래스에는 주어진 행렬에서 지정된 행 / 열을 삭제하는 row_del () 및 col_del () 메서드가 있습니다.

>>> M=Matrix(2,3,[10,40,30,2,6,9]) 
>>> M.col_del(1) 
>>> M

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

Matrix([[10, 30],[ 2, 9]])

다음 명령을 사용하여 출력에 스타일을 적용 할 수 있습니다.

$\displaystyle \left[\begin{matrix}10 & 30\\2 & 9\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[10 30 2 9]

>>> M.row_del(0) 
>>> M

$\displaystyle \left[\begin{matrix}2 & 9\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[2 9]

마찬가지로 row_insert () 및 col_insert () 메서드는 지정된 행 또는 열 인덱스에 행 또는 열을 추가합니다.

>>> M1=Matrix([[10,30]]) 
>>> M=M.row_insert(0,M1)
>>> M

$\displaystyle \left[\begin{matrix}10 & 30\\2 & 9\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[10 40 30 2 9]

>>> M2=Matrix([40,6]) 
>>> M=M.col_insert(1,M2) 
>>> M

$\displaystyle \left[\begin{matrix}10 & 40 & 30\\2 & 6 & 9\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[10 40 30 6 9]

산술 연산

일반 연산자 +,-및 *는 더하기, 빼기 및 곱하기를 수행하기 위해 정의됩니다.

>>> M1=Matrix([[1,2,3],[3,2,1]]) 
>>> M2=Matrix([[4,5,6],[6,5,4]]) 
>>> M1+M2

$\displaystyle \left[\begin{matrix}5 & 7 & 9\\9 & 7 & 5\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[5 7 9 9 7 5]

>>> M1-M2
$\displaystyle \left[\begin{matrix}-3 & -3 & -3\\-3 & -3 & -3\end{matrix}\right]$

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[- 3 -3 -3 -3 -3 -3]

행렬 곱셈은 다음 경우에만 가능합니다.-첫 번째 행렬의 열 수가 두 번째 행렬의 행 수와 같아야합니다. -결과는 첫 번째 행렬과 동일한 행 수, 두 번째 행렬과 동일한 열 수를 갖습니다.

>>> M1=Matrix([[1,2,3],[3,2,1]]) 
>>> M2=Matrix([[4,5],[6,6],[5,4]]) 
>>> M1*M2
$\displaystyle \left[\begin{matrix}31 & 29\\29 & 31\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[31 29 29 31]

>>> M1.T
$\displaystyle \left[\begin{matrix}1 & 3\\2 & 2\\3 & 1\end{matrix}\right]$

다음 출력은 코드를 실행 한 후 얻습니다.

[1 3 2 2 3 1]

행렬의 행렬식을 계산하려면 det () 메서드를 사용하십시오. 행렬식은 정사각형 행렬의 요소에서 계산할 수있는 스칼라 값입니다.

>>> M=Matrix(3,3,[10,20,30,5,8,12,9,6,15])
>>> M
$\displaystyle \left[\begin{matrix}10 & 20 & 30\\5 & 8 & 12\\9 & 6 & 15\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[10 20 30 5 8 12 9 6 15]

>>> M.det()

위 코드의 출력은 다음과 같습니다.

-120

매트릭스 생성자

SymPy는 많은 특수한 유형의 매트릭스 클래스를 제공합니다. 예를 들어, 단위 행렬, 모두 0과 1로 구성된 행렬 등이 있습니다. 이러한 클래스는 각각 눈, 0 및 1로 명명됩니다. 단위 행렬은 대각선으로 떨어지는 요소가 1로 설정되고 나머지 요소는 0으로 설정된 정사각형 행렬입니다.

Example

from sympy.matrices import eye eye(3)

Output

Matrix([[1, 0, 0], [0, 1, 0], [0, 0, 1]])
$\displaystyle \left[\begin{matrix}1 & 0 & 0\\0 & 1 & 0\\0 & 0 & 1\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[1 0 0 0 1 0 0 0 1]

진단 행렬에서 대각선의 요소는 제공된 인수에 따라 초기화됩니다.

>>> from sympy.matrices import diag 
>>> diag(1,2,3)

$\displaystyle \left[\begin{matrix}1 & 0 & 0\\0 & 2 & 0\\0 & 0 & 3\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[1 0 0 0 2 0 0 0 3]

0 행렬의 모든 요소는 0으로 초기화됩니다.

>>> from sympy.matrices import zeros 
>>> zeros(2,3)

$\displaystyle \left[\begin{matrix}0 & 0 & 0\\0 & 0 & 0\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[0 0 0 0 0 0]

마찬가지로 1은 모든 요소가 1로 설정된 행렬입니다.

>>> from sympy.matrices import ones
>>> ones(2,3)

$\displaystyle \left[\begin{matrix}1 & 1 & 1\\1 & 1 & 1\end{matrix}\right]$

위 코드의 출력은 다음과 같습니다.

[1 1 1 1 1 1]

Sympy 패키지에는 sympy.core.function 모듈에 정의 된 Function 클래스가 있습니다. 정의되지 않은 함수 클래스의 생성자이기도 한 모든 적용된 수학 함수의 기본 클래스입니다.

함수의 다음 범주는 함수 클래스에서 상속됩니다-

  • 복소수 함수
  • 삼각 함수
  • 정수 함수
  • 조합 기능
  • 기타 기타 기능

복소수 함수

이 기능 세트는 sympy.functions.elementary.complexes 기준 치수.

re

이 함수는 표현식의 실제 부분을 반환합니다.

>>> from sympy import * 
>>> re(5+3*I)

위 코드 스 니펫의 출력은 다음과 같습니다.

5

>>> re(I)

위 코드 스 니펫의 출력은 다음과 같습니다.

0

Im

이 함수는 표현식의 허수 부분을 반환합니다.

>>> im(5+3*I)

위 코드 스 니펫의 출력은 다음과 같습니다.

3

>>> im(I)

위 코드 스 니펫의 출력은 다음과 같습니다.

1

sign

이 함수는 식의 복소수 부호를 반환합니다.

실제 표현을 위해 기호는-

  • 식이 양수이면 1
  • expression이 0이면 0
  • 식이 음수이면 -1

식이 허수이면 반환되는 부호는 다음과 같습니다.

  • im (expression)이 양수이면 I
  • -I im (expression)이 음수이면
>>> sign(1.55), sign(-1), sign(S.Zero)

위 코드 스 니펫의 출력은 다음과 같습니다.

(1, -1, 0)

>>> sign (-3*I), sign(I*2)

위 코드 스 니펫의 출력은 다음과 같습니다.

(-I, I)

Abs

이 함수는 복소수의 절대 값을 반환합니다. 복소면에서 원점 (0,0)과 점 (a, b) 사이의 거리로 정의됩니다. 이 함수는 기호 값을 허용하는 내장 함수 abs ()의 확장입니다.

>>> Abs(2+3*I)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\sqrt13$

conjugate

이 함수는 복소수의 켤레를 반환합니다. 복잡한 켤레를 찾기 위해 허수 부의 부호를 변경합니다.

>>> conjugate(4+7*I)

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

4 - 7i

삼각 함수

SymPy는 모든 삼각비 (sin cos, tan 등)뿐만 아니라 asin, acos, atan 등과 같은 역 대응 비율에 대한 정의를 가지고 있습니다.이 함수는 라디안으로 표현 된 주어진 각도에 대해 각각의 값을 계산합니다.

>>> sin(pi/2), cos(pi/4), tan(pi/6)

위 코드 스 니펫의 출력은 다음과 같습니다.

(1, sqrt(2)/2, sqrt(3)/3)

>>> asin(1), acos(sqrt(2)/2), atan(sqrt(3)/3)

위 코드 스 니펫의 출력은 다음과 같습니다.

(pi/2, pi/4, pi/6)

정수에 대한 함수

정수에 대한 다양한 연산을 수행하는 기능 집합입니다.

ceiling

이것은 인수보다 작지 않은 가장 작은 정수 값을 반환하는 일 변량 함수입니다. 복소수의 경우 실수 부와 허수 부의 상한선을 분리합니다.

>>> ceiling(pi), ceiling(Rational(20,3)), ceiling(2.6+3.3*I)

위 코드 스 니펫의 출력은 다음과 같습니다.

(4, 7, 3 + 4*I)

floor

이 함수는 인수보다 크지 않은 가장 큰 정수 값을 반환합니다. 복소수의 경우에도이 함수는 실수 부와 허수 부의 바닥을 분리합니다.

>>> floor(pi), floor(Rational(100,6)), floor(6.3-5.9*I)

위 코드 스 니펫의 출력은 다음과 같습니다.

(3, 16, 6 - 6*I)

frac

이 함수는 x의 분수 부분을 나타냅니다.

>>> frac(3.99), frac(Rational(10,3)), frac(10)

위 코드 스 니펫의 출력은 다음과 같습니다.

(0.990000000000000, 1/3, 0)

조합 기능

조합 학은 유한 또는 이산 시스템 내에서 선택, 배열 및 작동 문제와 관련된 수학 분야입니다.

factorial

계승은 n 개의 객체가 치환 될 수있는 방법의 수를 제공하는 조합 학에서 매우 중요합니다. 상징적으로 ð ?? '¥! 이 함수는 음이 아닌 정수에 대한 계승 함수의 구현이며 음의 정수의 계승은 복소수 무한대입니다.

>>> x=Symbol('x') 
>>> factorial(x)

위 코드 스 니펫의 출력은 다음과 같습니다.

x!

>>> factorial(5)

위 코드 스 니펫의 출력은 다음과 같습니다.

120

>>> factorial(-1)

위 코드 스 니펫의 출력은 다음과 같습니다.

$\infty\backsim$

이항식

이 함수는 n 개의 요소 집합에서 k 개의 요소를 선택할 수있는 여러 가지 방법입니다.

>>> x,y=symbols('x y') 
>>> binomial(x,y)

위 코드 스 니펫의 출력은 다음과 같습니다.

$(\frac{x}{y})$

>>> binomial(4,2)

위 코드 스 니펫의 출력은 다음과 같습니다.

6

이항 함수를 사용하여 파스칼의 삼각형 행을 생성 할 수 있습니다.

>>> for i in range(5): print ([binomial(i,j) for j in range(i+1)])

위의 코드를 실행하면 다음과 같은 출력이 나타납니다.

[1]

[1, 1]

[1, 2, 1]

[1, 3, 3, 1]

[1, 4, 6, 4, 1]

fibonacci

피보나치 수는 초기 항 F0 = 0, F1 = 1 및 2 항 반복 관계 Fn = Fnâˆ'1 + Fnâˆ'2에 의해 정의 된 정수 시퀀스입니다.

>>> [fibonacci(x) for x in range(10)]

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

[0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

tribonacci

트리 보나 치 수는 초기 항 F0 = 0, F1 = 1, F2 = 1 및 3 항 반복 관계 Fn = Fn-1 + Fn-2 + Fn-3에 의해 정의 된 정수 시퀀스입니다.

>>> tribonacci(5, Symbol('x'))

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^8 + 3x^5 + 3x^2$

>>> [tribonacci(x) for x in range(10)]

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

[0, 1, 1, 2, 4, 7, 13, 24, 44, 81]

기타 기능

다음은 자주 사용되는 기능 목록입니다.

Min− 목록의 최소값을 반환합니다. 내장 함수 min과의 충돌을 피하기 위해 이름이 Min입니다.

Max− 목록의 최대 값을 반환합니다. 내장 함수 max와의 충돌을 피하기 위해 이름은 Max입니다.

root − x의 n 번째 루트를 반환합니다.

sqrt − x의 주요 제곱근을 반환합니다.

cbrt −이 함수는 x의 주 세제곱근을 계산합니다 (x ++ Rational (1,3)의 바로 가기).

다음은 위의 기타 기능 및 해당 출력의 예입니다.

>>> Min(pi,E)

e

>>> Max(5, Rational(11,2))

$\frac{11}{2}$

>>> root(7,Rational(1,2))

49

>>> sqrt(2)

$\sqrt2$

>>> cbrt(1000)

10

수학에서 쿼터니언 수 체계는 복소수의 확장입니다. 각 Quaternion 객체에는 4 개의 스칼라 변수와 4 개의 차원, 하나의 실제 차원과 3 개의 가상 차원이 포함됩니다.

Quaternion은 다음 식으로 표현됩니다-

q = a + bi + cj + dk

어디 a, b, c d는 실수이고 i, j, k 쿼터니언 단위는 i2 == j2 == k2 == ijk입니다.

그만큼 sympy.algebras.quaternion 모듈에는 Quaternion 클래스가 있습니다.

>>> from sympy.algebras.quaternion import Quaternion 
>>> q=Quaternion(2,3,1,4) 
>>> q

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$2 + 3i + 1j + 4k$

쿼터니언은 순수 수학뿐만 아니라 응용 수학, 컴퓨터 그래픽, 컴퓨터 비전 등에 사용됩니다.

>>> from sympy import * 
>>> x=Symbol('x') 
>>> q1=Quaternion(x**2, x**3, x) >>> q1

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$x^2 + x^3i + xj + 0k$

Quaternion 객체는 가상 계수도 가질 수 있습니다.

>>> q2=Quaternion(2,(3+2*I), x**2, 3.5*I) 
>>> q2

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$2 + (3 + 2i)i + x2j + 3.5ik$

더하다()

Quaternion 클래스에서 사용할 수있는이 메서드는 두 개의 Quaternion 객체를 추가합니다.

>>> q1=Quaternion(1,2,3,4) 
>>> q2=Quaternion(4,3,2,1) 
>>> q1.add(q2)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$5 + 5i + 5j + 5k$

Quaternion 개체에 숫자 나 기호를 추가 할 수 있습니다.

>>> q1+2

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$3 + 2i + 3j + 4k$

>>> q1+x

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$(x + 1) + 2i + 3j + 4k$

mul ()

이 방법은 두 쿼터니언 객체의 곱셈을 수행합니다.

>>> q1=Quaternion(1,2,1,2) 
>>> q2=Quaternion(2,4,3,1) 
>>> q1.mul(q2)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$(-11) + 3i + 11j + 7k$

역()

이 메서드는 쿼터니언 객체의 역을 반환합니다.

>>> q1.inverse()

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{1}{10} + (-\frac{1}{5})i + (-\frac{1}{10})j + (-\frac{1}{5})k$

펑 ()

이 메서드는 쿼터니언 객체의 거듭 제곱을 반환합니다.

>>> q1.pow(2)

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$(-8) + 4i + 2j + 4k$

exp ()

이 방법은 Quaternion 객체 즉 eq의 지수를 계산합니다.

>>> q=Quaternion(1,2,4,3) 
>>> q.exp()

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$e\cos(\sqrt29) + \frac{2\sqrt29e\sin(\sqrt29)}{29}i + \frac{4\sqrt29e\sin(\sqrt29)}{29}j + \frac{3\sqrt29e\sin}{29}k$

기호 = 및 ==는 Python에서 할당 및 등호 연산자로 정의되므로 기호 방정식을 공식화하는 데 사용할 수 없습니다. SymPy는 방정식을 설정하는 Eq () 함수를 제공합니다.

>>> from sympy import * 
>>> x,y=symbols('x y') 
>>> Eq(x,y)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

x = y

x = y는 xy = 0 일 때만 가능하므로 위의 방정식은 다음과 같이 쓸 수 있습니다.

>>> Eq(x-y,0)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

x − y = 0

SymPy의 솔버 모듈은 프로토 타입이 다음과 같은 soveset () 함수를 제공합니다.

solveset(equation, variable, domain)

도메인은 기본적으로 S.Complexes입니다. solveset () 함수를 사용하여 다음과 같이 대수 방정식을 풀 수 있습니다.

>>> solveset(Eq(x**2-9,0), x)

다음 출력을 얻습니다-

{−3, 3}

>>> solveset(Eq(x**2-3*x, -2),x)

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

{1,2}

solveset의 출력은 솔루션의 FiniteSet입니다. 솔루션이 없으면 EmptySet이 반환됩니다.

>>> solveset(exp(x),x)

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$\varnothing$

일차 방정식

선형 방정식을 풀려면 linsolve () 함수를 사용해야합니다.

예를 들어, 방정식은 다음과 같습니다.

xy = 4

x + y = 1

>>> from sympy import * 
>>> x,y=symbols('x y') 
>>> linsolve([Eq(x-y,4),Eq( x + y ,1) ], (x, y))

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

$\lbrace(\frac{5}{2},-\frac{3}{2})\rbrace$

linsolve () 함수는 행렬 형식으로 표현 된 선형 방정식을 풀 수도 있습니다.

>>> a,b=symbols('a b') 
>>> a=Matrix([[1,-1],[1,1]]) 
>>> b=Matrix([4,1]) 
>>> linsolve([a,b], (x,y))

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

$\lbrace(\frac{5}{2},-\frac{3}{2})\rbrace$

비선형 방정식

이를 위해 nonlinsolve () 함수를 사용합니다. 이 예에 대한 방정식-

a 2 + a = 0 ab = 0

>>> a,b=symbols('a b') 
>>> nonlinsolve([a**2 + a, a - b], [a, b])

위의 코드를 실행하면 다음과 같은 결과가 나옵니다.

$\lbrace(-1, -1),(0,0)\rbrace$

미분 방정식

먼저 cls = Function을 symbols 함수에 전달하여 정의되지 않은 함수를 만듭니다. 미분 방정식을 풀려면 dsolve를 사용하십시오.

>>> x=Symbol('x') 
>>> f=symbols('f', cls=Function) 
>>> f(x)

위의 코드 조각을 실행 한 후 다음 출력을 얻습니다.

f(x)

여기서 f (x)는 평가되지 않은 함수입니다. 그 파생물은 다음과 같습니다-

>>> f(x).diff(x)

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$\frac{d}{dx}f(x)$

먼저 다음 미분 방정식에 해당하는 Eq 객체를 생성합니다.

>>> eqn=Eq(f(x).diff(x)-f(x), sin(x)) 
>>> eqn

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$-f(x) + \frac{d}{dx}f(x)= \sin(x)$

>>> dsolve(eqn, f(x))

위의 코드 스 니펫은 아래 표현식과 동일한 출력을 제공합니다.

$f(x)=(c^1-\frac{e^-xsin(x)}{2}-\frac{e^-xcos(x)}{2})e^x$

SymPy는 Matplotlib 라이브러리를 백엔드로 사용하여 수학 함수의 2D 및 3D 플롯을 렌더링합니다. 현재 Python 설치에서 Matplotlib를 사용할 수 있는지 확인합니다. 그렇지 않은 경우 다음 명령을 사용하여 동일하게 설치하십시오-

pip install matplotlib

플로팅 지원은 sympy.plotting 모듈에 정의되어 있습니다. 플로팅 모듈에는 다음과 같은 기능이 있습니다.

  • plot − 2D 라인 플롯

  • plot3d − 3D 라인 플롯

  • plot_parametric − 2D 파라 메트릭 플롯

  • plot3d_parametric − 3D 파라 메트릭 플롯

plot () 함수는 Plot 클래스의 인스턴스를 반환합니다. 플롯 그림에는 하나 이상의 SymPy 표현식이있을 수 있습니다. Matplotlib를 백엔드로 사용할 수 있지만 texplot, pyglet 또는 Google 차트 API와 같은 다른 백엔드도 사용할 수 있습니다.

plot(expr, range, kwargs)

여기서 expr은 유효한 symPy 표현식입니다. 언급되지 않은 경우 범위는 기본값을 (-10, 10)으로 사용합니다.

다음 예제는 범위 (-10,10) −의 각 값에 대해 x2 값을 플로팅합니다.

>>> from sympy.plotting import plot 
>>> from sympy import * 
>>> x=Symbol('x') 
>>> plot(x**2, line_color='red')

동일한 범위에 대해 여러 플롯을 그리려면 범위 튜플 앞에 여러 표현식을 제공하십시오.

>>> plot( sin(x),cos(x), (x, -pi, pi))

각 표현식에 대해 별도의 범위를 지정할 수도 있습니다.

plot((expr1, range1), (expr2, range2))

다음 그림은 서로 다른 범위에서 sin (x) 및 cos (x)를 표시합니다.

>>> plot( (sin(x),(x, -2*pi, 2*pi)),(cos(x), (x, -pi, pi)))

다음 선택적 키워드 인수는 plot () 함수에 지정할 수 있습니다.

  • line_color − 플롯 라인의 색상을 지정합니다.

  • title − 제목으로 표시 할 문자열

  • xlabel − X 축의 레이블로 표시 할 문자열

  • ylabel − y 축의 레이블로 표시 할 문자열

>>> plot( (sin(x),(x, -2*pi, 2*pi)),(cos(x), (x, -pi, pi)), line_color='red', title='SymPy plot example')

plot3d () 함수는 3 차원 플롯을 렌더링합니다.

plot3d(expr, xrange, yrange, kwargs)

다음 예제는 3D 표면도를 그립니다.

>>> from sympy.plotting import plot3d 
>>> x,y=symbols('x y') 
>>> plot3d(x*y, (x, -10,10), (y, -10,10))

2D 플롯에서와 같이 3 차원 플롯에는 각각 다른 범위의 여러 플롯이있을 수도 있습니다.

>>> plot3d(x*y, x/y, (x, -5, 5), (y, -5, 5))

plot3d_parametric_line () 함수는 3 차원 파라 메트릭 라인 플롯을 렌더링합니다.

>>> from sympy.plotting import plot3d_parametric_line 
>>> plot3d_parametric_line(cos(x), sin(x), x, (x, -5, 5))

파라 메트릭 표면도를 그리려면 plot3d_parametric_surface () 함수를 사용하십시오.

plot3d_parametric_surface(xexpr, yexpr, zexpr, rangex, rangey, kwargs)

>>> from sympy.plotting import plot3d_parametric_surface 
>>> plot3d_parametric_surface(cos(x+y), sin(x-y), x-y, (x, -5, 5), (y, -5, 5))

SymPy의 지오메트리 모듈을 사용하면 선, 원 등과 같은 2 차원 개체를 만들 수 있습니다. 그런 다음 공선 성 확인 또는 교차점 찾기와 같은 개체에 대한 정보를 얻을 수 있습니다.

포인트

포인트 클래스는 유클리드 공간의 포인트를 나타냅니다. 다음 예제는 점의 공선 성을 확인합니다-

>>> from sympy.geometry import Point 
>>> from sympy import * 
>>> x=Point(0,0) 
>>> y=Point(2,2) 
>>> z=Point(4,4) 
>>> Point.is_collinear(x,y,z)

Output

True

>>> a=Point(2,3) 
>>> Point.is_collinear(x,y,a)

Output

False

Point 클래스의 distance () 메서드는 두 지점 사이의 거리를 계산합니다.

>>> x.distance(y)

Output

$2\sqrt2$

거리는 기호로 표현 될 수도 있습니다.

선 엔티티는 두 개의 Point 개체에서 가져옵니다. 교차점 () 메서드는 두 선이 서로 교차하는 경우 교차점을 반환합니다.

>>> from sympy.geometry import Point, Line 
>>> p1, p2=Point(0,5), Point(5,0) 
>>> l1=Line(p1,p2)
>>> l2=Line(Point(0,0), Point(5,5)) 
>>> l1.intersection(l2)

Output

[Point2D(5/2, 5/2)]

>>> l1.intersection(Line(Point(0,0), Point(2,2)))

Output

[Point2D(5/2, 5/2)]

>>> x,y=symbols('x y') 
>>> p=Point(x,y) 
>>> p.distance(Point(0,0))

Output

$\sqrt{x^2 + y^2}$

삼각형

이 함수는 세 점 개체에서 삼각형 개체를 만듭니다.

Triangle(a,b,c)

>>> t=Triangle(Point(0,0),Point(0,5), Point(5,0)) 
>>> t.area

Output

$-\frac{25}{2}$

타원

타원형 기하학 엔티티는 중심에 해당하는 Point 객체와 수평 및 수직 반경에 대해 각각 두 개의 숫자를 전달하여 구성됩니다.

ellipse(center, hradius, vradius)

>>> from sympy.geometry import Ellipse, Line 
>>> e=Ellipse(Point(0,0),8,3) 
>>> e.area

Output

$24\pi$

편심 매개 변수를 사용하여 vradius를 간접적으로 제공 할 수 있습니다.

>>> e1=Ellipse(Point(2,2), hradius=5, eccentricity=Rational(3,4)) 
>>> e1.vradius

Output

$\frac{5\sqrt7}{4}$

그만큼 apoapsis 타원의 초점과 윤곽선 사이의 가장 큰 거리입니다.

>>> e1.apoapsis

Output

$\frac{35}{4}$

다음 문은 타원의 둘레를 계산합니다-

>>> e1.circumference

Output

$20E(\frac{9}{16})$

그만큼 equation 타원 방법은 타원 방정식을 반환합니다.

>>> e1.equation(x,y)

Output

$(\frac{x}{5}-\frac{2}{5})^2 + \frac{16(y-2)2}{175} - 1$

수학에서 집합은 숫자, 사람, 알파벳 문자 또는 다른 집합 일 수있는 뚜렷한 개체의 잘 정의 된 모음입니다. Set은 또한 Python의 내장 유형 중 하나입니다. SymPy는 세트 모듈을 제공합니다. 다양한 유형의 집합에 대한 정의가 포함되어 있으며 교차, 합집합 등과 같은 집합 작업을 수행하는 기능이 있습니다.

Set은 SymPy에있는 다른 모든 유형의 집합에 대한 기본 클래스입니다. Python의 내장 세트 데이터 유형과는 다릅니다. Interval 클래스는 실제 간격을 나타내며 해당 경계 속성은FiniteSet 목적.

>>> from sympy import Interval 
>>> s=Interval(1,10).boundary 
>>> type(s)

sympy.sets.sets.FiniteSet

FiniteSet은 이산 숫자 모음입니다. 목록 또는 문자열과 같은 모든 시퀀스 개체에서 가져올 수 있습니다.

>>> from sympy import FiniteSet 
>>> FiniteSet(range(5))

Output

$\lbrace\lbrace0,1,...,4\rbrace\rbrace$

>>> numbers=[1,3,5,2,8] 
>>> FiniteSet(*numbers)

Output

$\lbrace1,2,3,5,8\rbrace$

>>> s="HelloWorld" 
>>> FiniteSet(*s)

Output

{H,W,d,e,l,o,r}

내장 세트에서와 같이 SymPy의 세트는 고유 한 오브젝트의 모음이기도합니다.

ConditionSet 주어진 조건을 충족하는 요소 집합입니다.

>>> from sympy import ConditionSet, Eq, Symbol 
>>> x=Symbol('x') 
>>> s=ConditionSet(x, Eq(x**2-2*x,0), Interval(1,10)) >>> s

Output

$\lbrace x\mid x\in[1,10]∧x^2 - 2x =0\rbrace$

Union복합 세트입니다. 두 세트의 모든 요소를 ​​포함합니다. 둘 다에있는 요소는 Union에서 한 번만 나타납니다.

>>> from sympy import Union 
>>> l1=[3,1,5,7] 
>>> l2=[9,7,2,1] 
>>> a=FiniteSet(*l1) 
>>> b=FiniteSet(*l2) 
>>> Union(a,b)

Intersection 반면에 둘 다에있는 요소 만 포함합니다.

>>> from sympy import Intersection 
>>> Intersection(a,b)

ProductSet 객체는 두 세트에있는 요소의 데카르트 곱을 나타냅니다.

>>> from sympy import ProductSet 
>>> l1=[1,2] 
>>> l2=[2,3] 
>>> a=FiniteSet(*l1) 
>>> b=FiniteSet(*l2) 
>>> set(ProductSet(a,b))

Complement(a,b) b 세트와 공통되는 제외 요소의 요소를 유지합니다.

>>> from sympy import Complement 
>>> l1=[3,1,5,7] 
>>> l2=[9,7,2,1] 
>>> a=FiniteSet(*l1) 
>>> b=FiniteSet(*l2) 
>>> Complement(a,b), Complement(b,a)

SymmetricDifference 세트는 두 세트 모두에서 일반적이지 않은 요소 만 포함합니다.

>>> from sympy import SymmetricDifference 
>>> l1=[3,1,5,7] 
>>> l2=[9,7,2,1] 
>>> a=FiniteSet(*l1) 
>>> b=FiniteSet(*l2) 
>>> SymmetricDifference(a,b)

Output

{2,3,5,9}

SymPy에서 사용할 수있는 여러 프린터가 있습니다. 다음은 부분 목록입니다-

  • str
  • srepr
  • ASCII 프리티 프린터
  • 유니 코드 프리티 프린터
  • LaTeX
  • MathML
  • Dot

SymPy 객체는 C, Fortran, Javascript, Theano 및 Python과 같은 다양한 언어의 코드로 출력으로 보낼 수도 있습니다.

SymPy는 유니 코드 문자를 사용하여 예쁜 인쇄물 형태로 출력을 렌더링합니다. SymPy 세션을 실행하기 위해 Python 콘솔을 사용하는 경우 init_session () 함수를 호출하여 가장 예쁜 인쇄 환경이 활성화됩니다.

>>> from sympy import init_session 
>>> init_session()

SymPy 1.5.1 용 IPython 콘솔 (Python 3.7.4-64 비트) (그라운드 유형 : python).

이 명령은 실행되었습니다-

>>> from __future__ import division
>>> from sympy import *
>>> x, y, z, t = symbols('x y z t')
>>> k, m, n = symbols('k m n', integer=True)
>>> f, g, h = symbols('f g h', cls=Function)
>>> init_printing()

문서는 다음에서 찾을 수 있습니다. https://docs.sympy.org/1.5.1/.

>>> Integral(sqrt(1/x),x)

$\int \sqrt\frac{1}{x} dx$

LATEX이 설치되어 있지 않지만 Matplotlib가 설치되어 있으면 Matplotlib 렌더링 엔진을 사용합니다. Matplotlib가 설치되지 않은 경우 유니 코드 프리티 프린터를 사용합니다. 그러나 Jupyter 노트북은 MathJax를 사용하여 LATEX을 렌더링합니다.

유니 코드를 지원하지 않는 단말기에서는 ASCII 프리티 프린터를 사용합니다.

ASCII 프린터를 사용하려면 use_unicode 속성이 False로 설정된 pprint () 함수를 사용하십시오.

>>> pprint(Integral(sqrt(1/x),x),use_unicode=False)

Unicode pretty 프린터는 pprint () 및 pretty ()에서도 액세스됩니다. 단말기가 유니 코드를 지원하면 자동으로 사용됩니다. pprint ()가 터미널이 유니 코드를 지원하는지 감지 할 수없는 경우 use_unicode = True를 전달하여 유니 코드를 사용하도록 할 수 있습니다.

LATEX 형식의 표현식을 얻으려면 latex () 함수를 사용하십시오.

>>> print(latex(Integral(sqrt(1/x),x)))

\int \sqrt{\frac{1}{x}}\, dx

mathml 프린터를 사용할 수도 있습니다. 이를 위해 print_mathml 함수를 가져옵니다. 문자열 버전은 mathml () 함수로 얻습니다.

>>> from sympy.printing.mathml import print_mathml 
>>> print_mathml(Integral(sqrt(1/x),x))

<apply>

<int/>

<bvar>

<ci>x</ci>

</bvar>

<apply>

<root/>

<apply>

<power/>

<ci>x</ci>

<cn>-1</cn>

</apply>

</apply>

</apply>

>>>mathml(Integral(sqrt(1/x),x))

'<apply><int/><bvar><ci>x</ci></bvar><apply><root/><apply><power/><ci>x</ci><cn>-1</cn></apply></apply></apply>'