正規(guī)制作網站公司哪家好西安全網優(yōu)化
文章目錄
- 前言
- 一、sympy基本函數(shù)介紹
- 變量定義
- 1. sp.Symbol("x") 或 sp.symbols("m n")
- 2. sp.Function("y")
- 3. func(x).diff(x, n)
- 定義方程與求解符號
- 1. sp.Eq(lhs, rhs)
- 2. 求解函數(shù)(*代表了常用且重要,其他部分作為拓展,可以有需要的時候再查詢使用)
- 3. func.subs(a, b) 或者 func.subs({a: b})
- 4. func.evalf(subs, n)
- 二、 常見錯誤(持續(xù)更新)
- TypeError: cannot create mpf from x
- TypeError: 'Equality' object is not subscriptable
- 三、計算模板
前言
本文將針對常用的函數(shù)進行用途分析與介紹,對代碼過程中可能會遇到的報錯進行分析,并給出實例幫助理解代碼。文章較長,可以針對感興趣的部分進行跳轉
一、sympy基本函數(shù)介紹
變量定義
1. sp.Symbol(“x”) 或 sp.symbols(“m n”)
這是定義變量,如f(x)中的x就是使用Symbol定義的
使用Symbol只能定義一個變量, 想要一次性定義多個變量,需要使用symbols,不同的變量之間用空格間隔
2. sp.Function(“y”)
定義函數(shù),相當于f(x)中的f,這時候程序沒法判斷它是誰的函數(shù),需要顯式的定義指定函數(shù)的變量,如f(x)
3. func(x).diff(x, n)
定義函數(shù)關于x的n階導數(shù)
在求解過程中盡量都采用diff方法,而非使用Derivative()函數(shù)
定義方程與求解符號
1. sp.Eq(lhs, rhs)
lhs, rhs 分別代表了等式左邊與等式右邊公式
例如y = x就需要表示為sp.Eq(y(x), x)
tip: 如果不是y(x),在求解這個等式的時候會報錯哦,一定要記得定義它是誰的函數(shù)
2. 求解函數(shù)(*代表了常用且重要,其他部分作為拓展,可以有需要的時候再查詢使用)
函數(shù)名稱 | 用途 | 主要參數(shù) | 說明 | 示例 |
---|---|---|---|---|
solve | 解普通方程的解析解 | f (方程或方程組)symbols (求解的變量)多個變量或方程需要用 [] 框起來 | 通用函數(shù),用于解一元或多元代數(shù)方程或方程組。 | solve(x**2 - 4, x) # 相當于求解 x 2 ? 4 = 0 x^2 - 4 = 0 x2?4=0 # [ -2, 2 ] |
nsolve | 解普通方程數(shù)值解 | f x (待求解變量)x0 (初始猜測值,與結果有關) | 用于求方程的數(shù)值解,需要輸入初始猜測值,并尋找該猜測值附近的數(shù)值解。通常返回一個近似解,也可使用 .evalf() 方法進行數(shù)值化。 | nsolve(sin(x) - 0.5, 0) # 因為是從0為初始值,求解 s i n ( x ) = 0.5 sin(x) = 0.5 sin(x)=0.5 最近的答案,所以應該是 π 6 \frac{\pi}{6} 6π?約等于0.5236 # 返回的結果是數(shù)值解 |
dsolve | 解微分方程 | eq (方程)func (求解的函數(shù),如 f(x) )ics (初始條件,可選) | 用于求解一階或高階常微分方程的解析解,支持線性和非線性方程。傳入 ics ,可以直接算出微分方程中的常數(shù)。 | x = symbols(‘x’) f = Function(‘f’)(x) ode = Eq(diff(f, x), f) # 求解最常規(guī)的微分方程 f ′ ( x ) = f ( x ) f'(x) = f(x) f′(x)=f(x) dsolve(ode, f) # [Eq( f ( x ) , C 1 ? e x f(x), C1* e^x f(x),C1?ex)] |
pdsolve | 解偏微分方程 (復雜一些時無法直接求解) | eq func | 專門用于求解偏微分方程的解析解,通常需要配合分離變量法。當直接輸入的偏微分方程過于復雜時,先進行變量分離再嘗試求解。 | # 一般使用方法類似 dsolve,但處理偏微分方程時 # pdsolve(eq, func) |
linsolve | 解線性方程組 (符號解) | system symbols | 適合求解線性方程組,返回向量形式的解。 | x, y = symbols(‘x y’) system = [x + y - 2, x - y - 0] linsolve(system, [x, y]) # 求解一個簡單的線性方程組,記住system里的式子右側都是0 # { (1, 1) } |
nonlinsolve | 解非線性方程組 (符號解) | system symbols | 用于求解非線性方程組,返回集合形式的符號解。 | x, y = symbols(‘x y’) system = [ x 2 + y ? 4 x^2 + y - 4 x2+y?4, x ? y 2 + 1 x - y^2 + 1 x?y2+1] nonlinsolve(system, [x, y]) |
solve_poly_system | 解多項式方程組 (多變量,符號解) | system symbols | 用于解特定的多項式方程組。 | # 用法與 solve 類似,但主要針對多項式方程 # solve_poly_system([Eq(…)], [x, y]) |
solve_univariate_inequality | 解一元不等式 | ineq (不等式)symbol (變量) | 用于求解一元不等式,返回區(qū)間形式或邏輯表達式。 | x = Symbol(‘x’, real=True) ineq = (x**2 < 4) solve_univariate_inequality(ineq, x) # -2 < x < 2 |
reduce_inequalities | 簡化或求解不等式組 | inequalities symbols | 簡化復雜的不等式組,返回符號形式的解集。 | x = symbols(‘x’, real=True) reduce_inequalities([[x > 1, x < 3]], [x]) # 1 < x < 3 |
3. func.subs(a, b) 或者 func.subs({a: b})
subs輸入一個字典或者兩個參數(shù),可以將變量換成指定的值,如上式中的a替換為了b
例如:
對于微分方程中輸出的結果中有C1,在已知某個初始值(如 y ( 0 ) = 1 2 y(0) = \frac{1}{2} y(0)=21?)的情況下,對結果
r e s = E q ( y ( x ) = C 1 e ? x + e x 2 ) res = Eq(y{\left(x \right)} = C_{1} e^{- x} + \frac{e^{x}}{2}) res=Eq(y(x)=C1?e?x+2ex?)進行常數(shù)的求解
C1 = sp.Symbol("C1") # 必須先定義C1是一個變量,才能作為nsolve中的實參進行求解
res = res.subs({y(x): 1/2, x: 0}) # 必須先替換y(x),再替換x
C = sp.nsolve(res, C1, 0) # 這樣就可以解得常數(shù)值
4. func.evalf(subs, n)
evalf是一個方法,是基于結果上的方法,可以計算某個表達式的具體值,也可以對nsolve的結果進行位數(shù)調整或者
例如:
(1 / a).evalf(subs={a: 2}, n=4)
# 結果為0.5000
二、 常見錯誤(持續(xù)更新)
TypeError: cannot create mpf from x
nsolve(f, x, x0), 這通常與nsolve中沒有初始值有關,設置一個初始值就好了
TypeError: ‘Equality’ object is not subscriptable
因為dsolve解的的結果是一個列表,使用dsolve[0]獲取的equality是不可用索引的
只能通過lhs和rhs分別獲得等式左右兩邊的式子
三、計算模板
- 設置變量, 利用symbols和Function設定變量與函數(shù)
- 利用sp.Eq設置等式
- 使用對應的solve函數(shù)進行求解(如有初值注意初值條件帶入)
- (可選)使用subs對求解的結果進行值代入,再使用nsolve對某些常量進行求解
例子 d y d x + y ( x ) = e x \frac{d y}{d x} + y{\left(x \right)} = e^{x} dxdy?+y(x)=ex
# 1. 進行變量設置
y = sp.Function('y')
x = sp.symbols('x')
y_ = y(x).diff(x) # 直接使用這個為一階導數(shù)
# 2. 設置方程
eq = sp.Eq(y_ + y(x), sp.exp(x))
# 3. 求解方程,因為是微分方程所以用dsolve
res = sp.dsolve(eq, y(x))
sp.pprint(res)# 4. 如果有初值
res = sp.dsolve(eq, y(x), ics={y(0):1}) # 使用ics(初始條件)可以直接求解常量
# 或對結果使用sub后利用nsolve求解