1

我有 4 个输入变量(浮点数):

  • 最大
  • 最小
  • 百分比
  • 模式

我想为 s 求解以下(相当长的)方程:

> (1/2+1/2*erf((log(Xmax)-(log(mode)+s**2))/(sqrt(2)*s))-(1/2+1/2*erf((log(Xmin)-(log(mode)+s**2))/(sqrt(2)*s))) - percentage == 0

我想使用 mpmath 和 sympy 来求解方程,但它给了我以下错误消息:

TypeError: cannot create mpf from 0.707106781186547*(-s**2 - 0.287682072451781)/s

我的代码如下:

from mpmath import erf, log, sqrt
from sympy import Symbol, solveset, S

percentage = 0.95
mode = 2
Xmin = 1.
Xmax = 1.5
s = Symbol('s')

eqn = (1/2+1/2*erf((log(Xmax)-(log(mode)+s**2))/(sqrt(2)*s))-(1/2+1/2*erf((log(Xmin)-(log(mode)+s**2))/(sqrt(2)*s))) - percentage)

solveset(eqn, s, domain=S.Reals)

mpf 是 mpmath 创建的浮点类型。

我想我将问题缩小到 erf() 函数,它返回

EmptySet()

当我跑步时

solveset(log(Xmax) - (log(mode) + s ** 2), s, domain=S.Reals)

我不知道接下来要尝试什么,任何帮助将不胜感激!

我最初认为这是数学问题,但方程在 matlab 中已成功求解,因此问题可能来自 sympy 或 mpmath。

4

1 回答 1

7

丢失 的mpmath导入erf并使用 sympy 版本可以解决您的错误。

from sympy import Symbol, solveset, S, erf, log, sqrt

percentage = 0.95
mode = 2
Xmin = 1.
Xmax = 1.5
s = Symbol('s', real=True)

eqn = (1/2+1/2*erf((log(Xmax)-(log(mode)+s**2))/(sqrt(2)*s))-(1/2+1/2*erf((log(Xmin)-(log(mode)+s**2))/(sqrt(2)*s))) - percentage)

solveset(eqn, s)

另请注意:

  • 您不必导入logsqrtmpmath. 从这里获取它们不会对您的结果产生影响sympy
  • 您可以在变量 s 上指定 Real 域,从而节省您在solveset调用时这样做。

如果需要,进一步使用的示例在此处的包测试中。

于 2016-06-12T12:09:01.533 回答