- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我之前发布了一个关于 C++ 函数 ceil()
、floor()
和 round()
的精度损失问题.问题链接如下。
Will ceil(), floor() and round() meet loss-of-precision problems when converted to integers?
从我收到的两个答案中,我了解到这些函数本身是精确的,但它们会放大现有的精度损失问题。
我想知道这些问题会被放大到什么程度。具体来说,请考虑以下事项。
a = fun(b);
这里,a
是一个整型值(int
、long
、long long
等), b
是一个float类型的值(float
, double
等),fun()
是ceil()
、floor()
和 round()
。请注意,在以下所有讨论中,我假设不存在上溢或下溢问题。
请注意,在这里,我假设 b 是通过其他一些可能导致精度损失的操作获得的。例如,假设我希望 b 等于 1.1 + 3.9 = 5,但是,由于无法表示 1.1 和 3.9,因此 b 不会以 5 结尾。
我想知道这些问题能在多大程度上影响a的值(value)。具体来说,a 的正确值(即,如果 b 没有精度损失)与实际获得的值(即,如果存在潜在的精度损失)有多少差异。假设我们将正确值表示为 a1,将实际值表示为 a2。在我看来,在任何情况下,以下结论都必须成立。
fun()
是 ceil()
,则 a2 等于 a1 或 a1 + 1。fun()
是 floor()
,则 a2 等于 a1 或 a1 - 1。fun()
是round()
,那么a2等于a1。我的问题是,如果我们忽略上溢和下溢
最佳答案
首先你假设你的错误是b
小的。如果错误在b
大于 1.0 那么你的结论都不成立。但大概在实践中错误 b
很小,这是一个合理的假设。
然而,结论 3 在所有情况下都是错误的。正确的结果是 a2 等于 a1 - 1,或 a1 + 1,或 a1。假设b的正确值为3.49999,实际值为3.50001则round
当正确结果为 3 时将给出 4。反之亦然,如果正确值为 3.50001 而实际值为 3.49999,则 round
当正确结果为 4 时将给出 3。
至于问题 2,没有简单的答案。而且不可能笼统地回答这个问题,所以需要一些关于你的实际问题的细节。听起来您在需要精确结果时试图使用不精确的算术。也许你需要切换到某种多精度算法,有几个库可以做到这一点,MPIR例如。
关于c++ - ceil、floor 和 round 函数会在多大程度上放大精度损失问题,以及如何消除此类影响?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57264084/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!