数值计算中的overflow and underflow

数值计算中的overflow and underflow

以softmax为例

实数在计算机内用二进制标识,所以不是一个精确值,当数值过小的时候,被四舍五入为0,这就是下溢出,而指数函数容易出现无穷大数而导致溢出错误,如e100=2.6881171418161356e+43,e1000=inf,这些无穷大无法进行除法运算,就出现OverflowError错误,这是因为计算机能够处理的“数”必须在4字节或者8字节的有限数值范围内。
下溢:当接近零的数被四舍五入为零时发生下溢。
上溢:大量级的数被近似为无穷时发生上溢。

如何解决

M = m a x ( x i ) M=max(x_i) M=max(xi),为所有x中的最大值,只需要把计算 f ( x i ) f(x_i) f(xi)的值变成计算 f ( x i − M ) f(x_i-M) f(xiM)的值就可以解决上述问题
理论依据:
在这里插入图片描述
在很多数值计算的library中,都采用了类似的方法来保持数值稳定。之前在实际项目中遇到过,怕遗忘,记录一下

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值