Triple Integration: ValueError: negative number cannot be raised to a fractional power

Triple Integration: ValueError: negative number cannot be raised to a fractional power

我正在尝试三重集成一个函数。

from scipy.integrate import tplquad

S = 40
P1 = 0.37
P2 = 0.43
P3V = .05
UND = 1 - (P1+P2+P3V)    

b1 = S*P1
b2 = S*P2
b3 = S*P3
b4 = S*UND

x1 = 48
x2 = 47
x3 = 4
x4 = 1

tp1 = tplquad(lambda x, y, z: ((x**(b1 + x1 - 1))*(y**(b2 + x2 - 1))*(z**(b3 + x3 - 1))*((1-x-y-z)**(x4+b4-1))), 0, 1, lambda z: z, lambda z: (1-z)/2, lambda x,z: 0, lambda x,z: x)

这是投掷:

ValueError: negative number cannot be raised to a fractional power

我正在尝试集成功能 (x**(b1 + x1 - 1))*(y**(b2 + x2 - 1))*(z**(b3 + x3 - 1))*((1-x-y-z)**(x4+b4-1))

超过以下限制:

谁能告诉我我做错了什么?

我稍微修改了一下以调试它:

def func(x, y, z):
    print(x, y, z)
    print(b1 + x1 - 1)
    print(b2 + x2 - 1)
    print(b3 + x3 - 1)
    print(1-x-y-z)
    print(x4+b4-1)
    return x**(b1 + x1 - 1) * y**(b2 + x2 - 1) * z**(b3 + x3 - 1) * (1-x-y-z)**(x4+b4-1)

所以当 运行集成时:

tp1 = tplquad(func, 0, 1, lambda z: z, lambda z: (1-z)/2, lambda x, z: 0, lambda x,z: x)

我得到以下信息:

0.25 0.375 0.5
61.8
63.2
5.0
-0.125
5.9999999999999964

1-x-y-z 中的 -0.125 是问题所在。您要求 Python 计算负数 (1-x-y-z)**(x4+b4-1) 的小数幂。在大多数情况下,结果会很复杂。

即使这不是问题(在 python-3.x 中,负数的小数幂不是问题!)它仍然会 运行 float-triplequad的要求:

>>> # Python-3.x
>>> tp1 = tplquad(func, 0, 1, lambda z: z, lambda z: (1-z)/2, lambda x, z: 0, lambda x,z: x)
TypeError: can't convert complex to float

因此您的函数似乎存在根本性错误(或边界不正确)。这是你必须解决的问题。我只能猜测可以做什么。