- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我的理解是:在 C++ 中用 double 减去两个 double
数字时,它们首先转换为以 2 的指数次方开始的尾数。如果相减的数字具有相同的指数并且尾数中有许多相同的数字,则可能会出错,从而导致精度损失。为了对我的代码进行测试,我编写了以下安全添加函数:
double Sadd(double d1, double d2, int& report, double prec) {
int exp1, exp2;
double man1=frexp(d1, &exp1), man2=frexp(d2, &exp2);
if(d1*d2<0) {
if(exp1==exp2) {
if(abs(man1+man2)<prec) {
cout << "Floating point error" << endl;
report=0;
}
}
}
return d1+d2;
}
然而,测试这个我注意到一些奇怪的事情:似乎实际错误(不是函数是否报告错误而是计算产生的实际错误)似乎取决于减去数字的绝对值而不仅仅是数字有效数字中的相等数字...
例如,使用1e-11
作为精度prec
并减去以下数字:
1) 9.8989898989898-9.8989898989897: 函数报错,我得到的值非常不正确 9.9475983006414e-14
2) 98989898989898-98989898989897: 函数报错但我得到正确值1
显然我误解了一些东西。有什么想法吗?
最佳答案
如果您减去两个几乎相等的浮点值,结果将主要反射(reflect)低位中的噪声。这里几乎相等不仅仅是相同的指数和几乎相同的数字。例如,1.0001 和 1.0000 几乎相等,减去它们可能会被这样的测试捕获。但是 1.0000 和 0.9999 的差值完全相同,不会被这样的测试捕获。
此外,这不是一个安全的加法函数。相反,它是对设计/编码错误的事后检查。如果你减去两个非常接近以至于噪音很重要的值,你就犯了一个错误。修正错误。我不反对使用类似这样的东西作为调试辅助工具,但请称它为暗示它就是这样的东西,而不是暗示浮点加法本身存在危险。此外,将检查放在加法函数中似乎过分:断言这两个值不会导致问题,然后进行普通的旧浮点加法,可能会更好。毕竟,代码中的大部分添加都不会导致问题,您最好知道问题点在哪里;将断言放在问题点。
关于c++浮点减法错误和绝对值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16281685/
我有一个用于“从”和“到”字段的日期选择器,我想要减法的结果。例如:toValue-fromValue,结果以小时为单位。如何做到这一点? 最佳答案 可以使用timeIntervalSinceDate
多边形之间可以进行 bool 运算吗? 我想在 OpenGL 中做一个这样的图形,我想用一个球体和四个较小的球体进行四次减法来实现。 最佳答案 不,仅使用 OpenGL 是不可能的。 OpenGL 是
这就是我在 Haskell 中进行矩阵加法的内容 > add :: (Num a) => [[a]] -> [[a]] -> [[a]] > add [] [] = [] >
我有两个约会: def lastRequestDate = "08-09-2019" (MM-dd-yyyy) 和 def Today = new Date().format('MM-dd-yyyy'
我在 Python 中玩弄大数,我计算了 2**(1322134) 而且显然计算了很长时间。然而,当我计算 2**(1322134) - 2**(1322134) 它立即返回 0。 Python 如
我正在尝试解决一个问题: 编写一个程序计算非负整数之间的差值。 输入: 输入的每一行都由一对整数组成。每个整数都在 0 到 10 之间提高到 15(含)。输入在文件末尾终止。 输出: 对于输入中的每一
是否可以有一个文本框,用户将在其中输入一个数字,而在另一个文本框中,它会自动将第一个文本框的值加 5 并从第三个文本框的值中减去 5? 例如: 用户输入:10 第二个文本框:15 第三个文本框:5 请
假设性问题。我的程序中有一个自定义对象,称为 GamePoint。它已正确定义并具有所有必需的成员。我想知道我是否可以实现类似于以下内容的东西: GamePoint p = new GamePoint
编辑 以前版本的问题没有准确反射(reflect)我的问题。我编辑了它。 我想做一系列破坏性的加法/减法(对具有相应方法的可变对象)。 a 被赋值后: a = [:a, :b] 以下所有返回语法错误。
我需要一个函数来计算 unsigned val 的总和和 signed dX并将结果包装在 lower 范围内和 upper 例如: 值为 5 , 变化 -6 , 以及 0 的范围和 10会返回 10
分而治之矩阵乘法是否执行与经典矩阵乘法相同数量的加法/减法? 我知道它们专门用于乘法运算,因为它们具有相同的 O(n^3) 复杂度... 但是当我尝试在我正在制作的程序中对它们进行计数时,加法/减法得
好的,我需要我的代码来检查减号/减号/-是否被按下,如果它被按下我想要弹出一个警告框。我尝试了 109 和 189 键码,但我仍然没有得到想要的结果。虽然我按 "-" 我没有得到那个警告框 最佳答案
如果我们想要映射一个将范围内的每个元素加 1 的函数,我们可以编写 map (\x -> x + 1) [1..5] 但我想大多数人都会选择 map (+1) [1..5] 相反。但这显然不适用于 (
我正在使用 lex 和 bison 进行简单的计算。它应该做的是解析每个提到的减法 - 1 - -1,1- 1,1--1,最多的是什么重要:1-1。前三种情况有效,但在最后一种情况下,它看起来好像将句
我有一个 MySQL 查询: $q = mysql_query("SELECT id FROM table ORDER BY id DESC LIMIT 2"); while($row = mysql
我有两个字符串列表,listA 和 listB。 listA 更长,我想通过向其添加空字符串来使 listB 具有相同的大小。 这个有效: int diff = listA.size() - list
我现在有两个相似的表(一个用于账单,另一个用于支付),我向用户展示了来自两者的联合混合数据.. Table Bills CustomerId
我有 2 个非索引数据框如下:df1 John Mullen 12/08/1993 Lisa Bush 06/12/1990 Maria Murphy 30/03/1989 Set
我有这个功能: (defun test (variable) (cond ((null variable) nil) (( (lisp-implementation-type) "
我有一个数据框 [in] MyDates [out] 2017-04-04 -5.0 2017-04-03 -5.0 2017-03-31 -4.0 201
我是一名优秀的程序员,十分优秀!