我目前在我的 python 程序中处理非常小的数字,例如
x = 200 + 2e-26
一种解决方案是使用对数值,这会增加浮点值的范围。问题是我也必须对这些值进行快速傅立叶变换,因此使用对数方法是不可用的(并且使用Decimal
-模块都不是)。还有其他方法可以解决这个问题吗?
编辑:我的问题decimal
模块是:如何处理虚值?我试过a = Decimal(1e-26)+Decimal(1e-26*1j)
and a = Decimal(1e-26)+Decimal(1e-26)*1j
,并且两种方法都失败(根据请求出错)。
考虑尝试一下mpmath package.
>>> from mpmath import mpf, mpc, mp
>>> mp.dps = 40
>>> mpf(200) + mpf(2e-26) + mpc(1j)
mpc(real='200.0000000000000000000000000200000000000007', imag='1.0')
大部分准确并且可以处理复杂的数字,更多详细信息请参阅文档.
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)