python - 在 python 中处理非常小的数字

标签 python

我目前在我的 python 程序中处理非常小的数字,例如

x = 200 + 2e-26

一种解决方案是使用对数值,这会增加我的浮点值的范围。问题是我也必须对这些值进行 fft,因此使用对数方法不可用(并且也不使用 Decimal-module)。还有其他方法可以解决这个问题吗?

编辑:decimal 模块的问题是:如何处理虚数?我尝试了 a = Decimal(1e-26)+Decimal(1e-26*1j)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')

大多数情况下是准确的,可以处理复杂的数字,documentation 中有更多详细信息.

关于python - 在 python 中处理非常小的数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29488213/

相关文章:

python - flask : What exactly is @app

python - 加载私钥失败,出现 OpenSSL.crypto.Error : []

python - 以合适的格式对 pandas 数据框进行分组以创建图表

python - 消息: unknown error: Chrome failed to start: exited abnormally on AWS Cloud9 with Linux 4. 9.85-38.58.amzn1.x86_64 x86_64

python - 不使用点符号间接访问 Python 实例属性

python - 循环只取最后一个值

python - 如何查看 sklearn.preprocessing.PolynomialFeatures 的效果?

python - 使用 python move 文件

python / Pandas : How many levels in a dataframe index?

python - Windows 中的信号处理