首页 > 其他 > 详细

数值计算中的上溢和下溢

时间:2018-09-05 16:37:10      阅读:241      评论:0      收藏:0      [点我收藏+]

利用计算机实现数值计算,指的通常是利用迭代过程更新解来解决数学问题,而不是通过解析过程推到数学公式求解。常见得数值计算主要包括优化问题求解和解线性方程组。

 

上溢和下溢

通常实数在计算机内不能精确保存,利用计算机保存实数时,几乎总会引入一些近似误差。在许多情况下,这仅仅是舍入误差,舍入误差会导致一些问题。特别是在一些复合操作下, 理论上可行的算法,如果在实际中没有考虑到舍入误差的累积,在实际算法运用过程中也会导致算法的失效。

 

其中一种情况就是下溢。即有些逼近零的数,如零除或者对零取对数时,得到-,如果对负无穷进一步运算,则会得到非数字;

 

还有一种情况就是上溢。即大量级的数被近似为正负无穷时,发生上溢。发生上溢后,这些数值也会变为非数值。

 

解决数值上溢和下溢方法的一个实例是使用softmax函数。

定义为:

考虑一下,当所有xi都等于一个常数C。则softmax函数的值为1/n。

如果C很大,exp(c)的上溢会导致整个表达式未定义;

如果C是一个很小的负数,exp(c)会下溢;

解决方法,计算softmax(z)

如此,上溢的问题可以得到解决。下溢的情况也由于分母不为零解决。

But,有个小问题,当计算Log(softmax(z))时,softmax(z)可能为0,从而导致不可解。

解决方法,使用相同的技巧来解log(softmax(z))。

 

不过在多数情况下,可以简单地依赖保证数值稳定地底层库。当需要自己实现算法的时候,则需要考虑数值稳定性的问题。

数值计算中的上溢和下溢

原文:https://www.cnblogs.com/xmd-home/p/9592140.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!