python中sympy庫(kù)求常微分方程的用法
問題1:

程序,如下
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)))
結(jié)果
Eq(f(x), (C1 + C2*x)*exp(x) + cos(x)/2)
附:布置考試中兩題
1.利用python的Sympy庫(kù)求解微分方程的解 y=f(x),并嘗試?yán)胢atplotlib繪制函數(shù)圖像

程序,如下
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 pltimport numpy as npx_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()
結(jié)果
Eq(f(x), -C1/(C1 - exp(x)))FiniteSet(1/2)

2.利用python的Sympy庫(kù)求解微分方程的解 y=y(x),并嘗試?yán)胢atplotlib繪制函數(shù)圖像

程序,如下
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 pltimport numpy as npx_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()
結(jié)果
Eq(y(x), C1*exp(x))FiniteSet(1)

到此這篇關(guān)于python中sympy庫(kù)求常微分方程的用法的文章就介紹到這了,更多相關(guān)python sympy常微分方程內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. JavaScript實(shí)現(xiàn)簡(jiǎn)單的彈窗效果2. Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求3. javascript實(shí)現(xiàn)貪吃蛇小練習(xí)4. 我所理解的JavaScript中的this指向5. Vue 實(shí)現(xiàn)對(duì)quill-editor組件中的工具欄添加title6. PHP驗(yàn)證碼工具-Securimage7. PHP單件模式和命令鏈模式的基礎(chǔ)知識(shí)8. 一文帶你徹底理解Java序列化和反序列化9. PHP利用curl發(fā)送HTTP請(qǐng)求的實(shí)例代碼10. js實(shí)現(xiàn)碰撞檢測(cè)

網(wǎng)公網(wǎng)安備