Lecture 강의

Undergrads 학부 Graduates 대학원 역학(Mech)/설계(Design)/FEM 인공지능(AI)/기계학습(ML)/IoT SAP/ETABS OpenSees/FeView/STKO 아바쿠스(Abaqus) 파이썬(Python)/매트랩(Matlab) 엑셀(Excel-VBA)/HTML 마이다스(MIDAS)

[03. 패키지 - SymPy] (1) 기본 함수, (2) 미분방정식(sy.dsolve), (3) (연립)방정식(sy.solve)

작성자 : kim2kie

(2023-02-19)

조회수 : 12249

SymPy는 변수를 심볼로 지정한 문자 연산이 가능하다.
Jupyter를 사용하여 웹에서 보기 쉽게 (LaTex로) 심볼을 나타낼 수 있다. 

(1) 기본 함수
(2) 미분방정식(dsolve)
    1) 2계 미분방정식(사용법)
    2) 2계 미분방정식(Matlab과 결과 그래프 비교)
(3) (연립)방정식(solve)

 


(1) 기본 함수

import sympy as sy

Ex) simplify() 간략하게
    x = sy.symbols('x')
    expr=2*x+3*x-sy.sin(x)-3*x+42
    sy.simplify(expr)
    결과: 2*x - sin(x) + 42

Ex) factor() 인수분해
    sy.factor(x**2-2*x-8)
    결과: (x - 4)*(x + 2)

Ex) expand() 전개
    sy.expand((x-4)*(x+2))
    결과: x**2 - 2*x - 8

Ex) collect(,x) x에 대해 정리
    m,n = sy.symbols("m,n")
    sy.collect(x**2+x*m+n*x+m*n, x)
    결과: m*n + x**2 + x*(m + n)

Ex) subs() 수식에 숫자 대입
    y = sy.symbols('y')
    expr = sy.sin(x) + sy.cos(y)
    expr.subs({x:1, y:2})
    결과: cos(2) + sin(1)

    expr.subs({x:1, y:2}).n()
    결과: 0.425324148260754

Ex) 삼각함수
    sy.sin(sy.pi/6)
    결과: 1/2
    sy.cos(sy.pi/6)
    결과: sqrt(3)/2
    sy.expand_trig(sy.sin(2*x))
    결과: 2*sin(x)*cos(x)

Ex) 복소수
    from sympy import I
    I*I
    결과: -1
    z=4+3*I
    sy.re(z)
    결과: 4
    sy.im(z)
    결과:3
    sy.Abs(z)
    결과: 5
    sy.arg(z)
    결과: atan(3/4)
    sy.conjugate(z)
    결과: 4 - 3*I

Ex) 미분
    sy.diff(x**3, x) # 1계 미분
    결과: 3*x**2
    sy.diff(x**2*sy.sin(x), x)
    결과: x**2*cos(x) + 2*x*sin(x)
    sy.diff(x**3, x, 2) # 2계 미분
    결과: 6*x

Ex) 적분
    sy.integrate(x**3, x)
    결과: x**4/4
    sy.integrate(sy.sin(x), x)
    결과: -cos(x)
    sy.integrate(sy.ln(x), x)
    결과: x*log(x) - x
    sy.integrate(x**3, (x, 0, 1))
    결과: 1/4

 

 

(2) 미분방정식

1) 2계 미분방정식(사용법)

미분방정식(ode): y" + 3y - 1 = 0
초기 조건(ics): y(1)=2
초기 조건(ics): y(0)=0, y'(0)=0

 

Ex)
import sympy as sy

x = sy.symbols('x')
f = sy.symbols('f',cls=sy.Function)
y = f(x)
eq = sy.Eq(sy.diff(y,x,2)+3*y-1,0) # 방정식 세우기
sy.dsolve(eq,y) # (일반) 방정식 풀기
sy.dsolve(eq,y,ics={f(1):2}) # 초기 조건(1개)인 경우
sy.dsolve(eq,y,ics={f(0):0, sy.diff(y,x).subs(x,0):0}) # 초기 조건(2개)인 경우

 

 

2) 2계 미분방정식(Matlab과 비교)


미분방정식(ode): u" + 8u' + 2u = cos(t)
초기 조건(ics): u(0)=0, u'(0)=1

 

참조: 김두기, 구조동역학, 구미서관, 2021

 

Ex)
from sympy import *

t = symbols('t')
u = symbols('u',cls=Function)
deq = Eq(u(t).diff(t,2) + 8*u(t).diff(t) + 2*u(t),cos(t)) # 방정식 세우기
usol = dsolve(deq,ics={u(0):0, u(t).diff(t).subs(t,0):1}) # 초기 조건(2개)

plot(usol.rhs,(t,0,50))

 

cf) grid 넣기
plot에 grid를 넣기 위해 다음 패키지를 불러들여 figure를 셋팅할 수 있다.

Ex)
import seaborn as sns
sns.set()
sns.set_style("whitegrid", {'grid.linestyle': '--'})

 

(3) 방정식

1) 방정식
x + (8/9)*135*(1-0.2*x)/(1-x)/351.372 = 1

Ex)
import sympy as sy

x = sy.symbols('x')
eq = sy.Eq(x + (8/9)*135*(1-0.2*x)/(1-x)/351.372,1) # 방정식 세우기
sy.solve(eq,x) # (일반) 방정식 풀기


 

2) 연립방정식

2y + 7x = −5
5y − 7x = 12


Ex)
import sympy as sy

x,y = sy.symbols('x y', real=True)
eq1 = 2*y+7*x+5
eq2 = 5*y-7*x-12
sol = sy.solve([eq1, eq2], x, y, dict=True);sol

결과: [{x: -1, y: 1}]