ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python 求常微分方程 sympy库

2020-04-28 16:39:40  阅读:588  来源: 互联网

标签:plt python eqr symbols exp import sympy C1 求常


问题1:
f(x)2f(x)+f(x)=sin(x)f''(x)-2f'(x) + f(x) = sin(x)f′′(x)−2f′(x)+f(x)=sin(x)

程序,如下

from sympy import *
f = symbols('f', cls=Function)
x = symbols('x')
eq = Eq(f(x).diff(x, x) - 2*f(x).diff(x) + f(x), sin(x))
print(dsolve(eq, f(x)))

结果

Eq(f(x), (C1 + C2*x)*exp(x) + cos(x)/2)

 ~ 
 ~ 
 ~ 
 ~ 
附:布置考试中两题
1.利用python的Sympy库求解微分方程的解 y=f(x)y=f(x)y=f(x),并尝试利用matplotlib绘制函数图像

f(x)+f(x)+f2(x)=0,f(0)=1f'(x)+f(x)+f^2(x)=0,\qquad f(0)=1f′(x)+f(x)+f2(x)=0,f(0)=1

程序,如下

from sympy import *
f = symbols('f', cls=Function)
x = symbols('x')
eq = Eq(f(x).diff(x,1)+f(x)+f(x)**2, 0)
print(dsolve(eq, f(x)))
C1 = symbols('C1')
eqr = -C1/(C1 - exp(x))
eqr1 = eqr.subs(x, 0)
print(solveset(eqr1 - 1, C1))
eqr2 = eqr.subs(C1, 1/2)
# 画图
import matplotlib.pyplot as plt
import numpy as np
x_1 = np.arange(-5, 5, 0.1)
y_1 = [-0.5/(0.5 - exp(x)) for x in x_1]
plt.plot(x_1, y_1)
plt.axis([-6,6,-10,10])
plt.grid()
plt.show()

结果

Eq(f(x), -C1/(C1 - exp(x)))
FiniteSet(1/2)

在这里插入图片描述
 ~ 
2.利用python的Sympy库求解微分方程的解 y=y(x)y=y(x)y=y(x),并尝试利用matplotlib绘制函数图像

y(x)=y(x),y(0)=1y'(x)=y(x),\qquad y(0)=1y′(x)=y(x),y(0)=1

程序,如下

from sympy import *
y = symbols('y', cls=Function)
x = symbols('x')
eq = Eq(y(x).diff(x,1), y(x))
print(dsolve(eq, y(x)))
C1 = symbols('C1')
eqr = C1*exp(x)
eqr1 = eqr.subs(x, 0)
print(solveset(eqr1 - 1, C1))
eqr2 = eqr.subs(C1, 1)
# 画图
import matplotlib.pyplot as plt
import numpy as np
x_1 = np.arange(-5, 5, 0.01)
y_1 = [exp(x) for x in x_1]
plt.plot(x_1, y_1, color='orange')
plt.grid()
plt.show()

结果

Eq(y(x), C1*exp(x))
FiniteSet(1)

在这里插入图片描述

标签:plt,python,eqr,symbols,exp,import,sympy,C1,求常
来源: https://blog.csdn.net/t4ngw/article/details/105779327

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有