我用sympy解决了二次方程式:
import sympy as sp
q,qm,k,c0,c,vt,vm = sp.symbols('q qm k c0 c vt vm')
c = ( c0 * vt - q * vm) / vt
eq1 = sp.Eq(qm * k * c / (1 + k * c) ,q)
q_solve = sp.solve(eq1,q)
根据一些测试,我发现只有q_solve[0]
具有物理意义。同情者总是将(b - sqrt(b**2 - 4*a*c))/2a
置于首位吗?我想,它可能随着升级而改变?
答案 0 :(得分:5)
回答你的问题的一个简单的测试是使用下面的sympy象征性地求解二次方程:
import sympy as sp
a, b, c, x = sp.symbols('a b c x')
solve( a*x**2 + b*x + c, x)
这会给你结果:
[(-b + sqrt(-4*a*c + b**2))/(2*a), -(b + sqrt(-4*a*c + b**2))/(2*a)]
这让我相信,一般来说,顺序首先是+ sqrt()
解决方案,然后是- sqrt()
解决方案。
对于您的计划q_solve[0]
,您可以:
(c0*k*vt + k*qm*vm + vt - sqrt(c0**2*k**2*vt**2 - 2*c0*k**2*qm*vm*vt + 2*c0*k*vt**2 + k**2*qm**2*vm**2 + 2*k*qm*vm*vt + vt**2))/(2*k*vm)
这仍然是x= (-b + sqrt(b**2-4*a*c))/(2*a)
答案,b
字词的负号会因解决方案中变量符号的分布而消失