sympy - 如何在 SymPy 中求解这个由两个方程组成的系统?

标签 sympy equation-solving

我有这个功能:

f(x) = 1 / (x + a)^t + b

我想为 ab 求解给定的 t 方程组 {f(0)= 1 和 f(1)=0}

对于 t=1,成功计算出一个解:

import sympy as sp
a,b = sp.symbols("a b")
res = sp.solve([1/(a+1)**1 +b, 1/a**1+b-1], [a,b])
res
# [(-1/2 + sqrt(5)/2, -sqrt(5)/2 + 1/2), (-sqrt(5)/2 - 1/2, 1/2 + sqrt(5)/2)]

但对于除 1 以外的任何 t(大多数情况下也是 2),找不到解决方案:

import sympy as sp
a,b = sp.symbols("a b")
res = sp.solve([1/(a+1)**1.5 +b, 1/a**1.5+b-1], [a,b])
res

给出:

NotImplementedError: could not solve 
b*(-(1 + sqrt(3)*I)*(1/(b**2 - 2*b + 1))**(1/3)/2 + 1)**(3/2) + 1

是否可以从更有效的角度在 SymPy 中解决这个问题?

我们也非常欢迎对有助于解决此问题的 Python 包提出建议。

最佳答案

你对 t 做了什么假设? 您当然可以使用例如数值求解非线性方程组scipy.optimize.root.

我写了一个实验包pyneqsys当你从符号表达式开始时帮助解决这个问题。在您的情况下,我将按如下方式使用它:

>>> import sympy as sp
>>> from pyneqsys.symbolic import SymbolicSys
>>> a, b, t = sp.symbols('a b t')
>>> f = lambda x: 1/(x+a)**t + b
>>> neqsys = SymbolicSys([a, b], [f(0) - 1, f(1) - 0], [t])
>>> ab, sol = neqsys.solve_scipy([0.5, -0.5], 1)
>>> ab, sol.success
(array([ 0.61803399, -0.61803399]), True)

您还可以在 t 从 0.5 到 3 变化时绘制结果:

>>> def solve(tval, guess=(.5, -.5)):
...     vals, sol = neqsys.solve_scipy(guess, tval)
...     assert sol.success
...     return vals
...
>>> import numpy as np
>>> import matplotlib.pyplot as plt
>>> trange = np.linspace(.5, 3)
>>> plt.plot(trange, np.array([solve(t_) for t_ in trange]))

matplotlib plot of solutions

关于sympy - 如何在 SymPy 中求解这个由两个方程组成的系统?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33135238/

相关文章:

python - 使用 tensorflow 逃避局部最小值

math - 求解包含二 Gamma 函数的方程组的最有效方法是什么?

python - Sympy 在简化时生成损坏的 `Piecewise` 条件

c - C中具有3个变量的线性方程

matlab - 如何在 MATLAB 中求解只有一个分量的线性系统

algorithm - 如何使用线性约束找到 sum(xi) =b 的所有整数解

python - 如何在 SymPy 中定义和解决相互引用的表达式

Python Sympy Latex Fraction 在没有先分解的情况下不会打印

python - 使用 Sympy 删除多项式的低阶项

python - SymPy:安全地解析字符串