码迷,mamicode.com
首页 > 其他好文 > 详细

数值计算中的上溢和下溢

时间:2018-09-05 17:50:07      阅读:259      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!