如何提取特定变量的所有系数

问题描述 投票:0回答:1

我在sympy中做了一些计算,结果如下:(我使用[expr].coeff(u1)方法)

X1*X2*(u1 - u2 + u3 - u4)/(4*a*b) + X1*(-u1 + u2 + u3 - u4)/(4*a) + X2*(-u1 - u2 + u3 + u4)/(4*b) + u1/4 + u2/4 + u3/4 + u4/4

我需要提取变量 u1 的所有系数(例如),它应该看起来像这样:

X1*X2/(4*a*b) + -X1/(4*a) + -X2/(4*b) + 1/4

但是 sympy 这样做:

1/4

在较小的尺度下 - 我需要 u1 的系数

(-u1 + u2 + u3 - u4)/(4*a)

应该看起来像这样:

-1/(4*a)

但是我发现了一些错误:

0

此处的代码示例:

import sympy as sp
import numpy as np

a0, a1, a2, a3, X1, X2, a, b = sp.symbols('a0 a1 a2 a3 X1 X2 a b')
u1, u2, u3, u4 = sp.symbols('u1 u2 u3 u4')
Disp = a0 + a1*X1 + a2*X2 + a3*X1*X2

Eq1 = Disp.subs({X1: -a, X2: -b})
Eq2 = Disp.subs({X1: a, X2: -b})
Eq3 = Disp.subs({X1: a, X2: b})
Eq4 = Disp.subs({X1: -a, X2: b})

sol = sp.solve([Eq1 - u1, Eq2 - u2, Eq3 - u3, Eq4 - u4]
               , [a0, a1, a2, a3], dict=True)
a0, a1, a2, a3 = sol[0][a0], sol[0][a1], sol[0][a2], sol[0][a3]
Disp1 = a0 + a1*X1 + a2*X2 + a3*X1*X2
# print(Disp1)
N1 = Disp1.as_expr()
N2 = Disp1.coeff(u2)
print(N2)
python sympy equation algebra
1个回答
0
投票

我只是使用 [sympy.expand(expr)].coeff(u1) 来获取:

X1*X2/(4*a*b) - X1/(4*a) - X2/(4*b) + 1/4

来自:

X1*X2*(u1 - u2 + u3 - u4)/(4*a*b) + X1*(-u1 + u2 + u3 - u4)/(4*a) + X2*(-u1 - u2 + u3 + u4)/(4*b) + u1/4 + u2/4 + u3/4 + u4/4

(希望答案对大家有帮助!!!)

© www.soinside.com 2019 - 2024. All rights reserved.