我在哪里可以找到C#中的机器epsilon?

我在哪里可以找到C#中的机器epsilon?,第1张

概述机器epsilon被规范地定义为加到一个的最小数字,给出与之不同的结果. 有一个Double.Epsilon,但名字是非常误导的:它是最小的(非规范化)双值可表示,因此对于任何类型的数字编程是无用的. 我想要获得Double类型的真正的epsilon,所以不必将公差硬编码到我的程序中.我该如何做? 这是(在我的机器上): 1.11022302462516E-16 你可以很容易地计算出来: doub 机器epsilon被规范地定义为加到一个的最小数字,给出与之不同的结果.

有一个Double.Epsilon,但名字是非常误导的:它是最小的(非规范化)双值可表示,因此对于任何类型的数字编程是无用的.

我想要获得Double类型的真正的epsilon,所以不必将公差硬编码到我的程序中.我该如何做?

解决方法 这是(在我的机器上):
1.11022302462516E-16

你可以很容易地计算出来:

double machEps = 1.0d;        do {           machEps /= 2.0d;        }        while ((double)(1.0 + machEps) != 1.0);        Console.Writeline( "Calculated machine epsilon: " + machEps );

编辑:

我计算了2倍的epsilon,现在应该是正确的.

总结

以上是内存溢出为你收集整理的我在哪里可以找到C#中的机器epsilon?全部内容,希望文章能够帮你解决我在哪里可以找到C#中的机器epsilon?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1257895.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存