所以,我在Python中遇到了一些精确问题。
我想计算这样的函数:
P(x,y) = exp(-x)/(exp(-x) + exp(-y))
x和y可能> 1000。 Python的math.exp(-1000)(至少在2.6中!)没有足够的浮点精度来处理这个问题。
(另外,我对标题持开放态度!对于这个问题,我想不出一个好的!)
答案 0 :(得分:8)
您可以按exp(-x)
P(x,y) = 1/(1 + exp(x-y))
答案 1 :(得分:8)
>>> import decimal
>>> decimal.Decimal(-1000).exp()
Decimal('5.075958897549456765291809480E-435')
>>> decimal.getcontext().prec = 60
>>> decimal.Decimal(-1000).exp()
Decimal('5.07595889754945676529180947957433691930559928289283736183239E-435')
答案 2 :(得分:4)
P(x,y) = exp(-x)/(exp(-x) + exp(-y))
相当于:
P(x,y) = 1 / (1 + exp(x-y))
也许第二个可以在不使用更高精度的情况下工作。
答案 3 :(得分:3)
我认为您正在寻找用于任意精度浮点可靠算术的bigfloat包。