我正在 Python 中实现 Viterbi 算法(一种动态算法),我注意到对于大型输入文件,概率不断增加并缩小到浮点精度之外。我需要将数字存储在日志空间中。
谁能给出一个简单的示例 Python 代码片段,说明如何将 0.0000003 转换为日志空间?(我不确定它是否需要自然日志或其他日志。我只听说过“日志空间”但并不真正了解它。)
谢谢!
我正在 Python 中实现 Viterbi 算法(一种动态算法),我注意到对于大型输入文件,概率不断增加并缩小到浮点精度之外。我需要将数字存储在日志空间中。
谁能给出一个简单的示例 Python 代码片段,说明如何将 0.0000003 转换为日志空间?(我不确定它是否需要自然日志或其他日志。我只听说过“日志空间”但并不真正了解它。)
谢谢!
要移动到日志空间,请使用log
. 要再次向后移动,请使用exp
. 日志空间中的规则是不同的- 例如。执行乘法是在日志空间中添加。
>>> from math import log, exp
>>> log(0.0000003)
-15.01948336229021
>>> exp(-15.01948336229021)
3.0000000000000015e-07
>>> log(0.0000003) + log(0.0000003)
-30.03896672458042
>>> exp(-30.03896672458042)
9.000000000000011e-14 # 0.0000003 * 0.0000003
这是一个使用一些小概率的例子
>>> probabilities = [0.0000003, 0.0000004, 0.0000005]
>>> exp(sum(log(p) for p in probabilities))
5.999999999999992e-20