- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了一个数学计算器,它从用户那里接收一个字符串并对其进行解析。它使用 double 来保存计算时涉及的所有值。解决后,我将其打印出来,并使用 std::setprecision()
确保其输出正确(例如 0.9999999
将变为 1
打印出来。
返回将要输出的字符串:
//return true or false if this is in the returnstring.
if (returnString.compare("True") == 0 || returnString.compare("False") == 0) return returnString;
//create stringstream and put the answer into the returnString.
std::stringstream stream;
returnString = std::to_string(temp_answer.answer);
//write into the stream with precision set correctly.
stream << std::fixed << std::setprecision(5) << temp_answer.answer;
return stream.str();
我知道使用 double 和 float 时的准确性问题。今天我开始编写代码,以便用户可以比较两个数学字符串。例如,1=1
将评估为真,2>3
为假...等。这是通过为比较运算符的每一侧运行我的数学表达式解析器,然后比较答案来实现的。
我现在面临的问题是当用户输入类似1/3*3=1
的内容时。当然因为我使用的是 double 解析器将返回 0.999999
作为答案。通常,在解决非比较问题时,如前所述,这会在打印时使用 std::setprecision()
进行补偿。但是,当比较两个 double 时,它将返回 false,如 0.99999!=1
。我怎样才能得到它,以便在比较 double 时补偿这种不准确性,并正确返回答案?这是我用来比较数字本身的代码。
bool math_comparisons::equal_to(std::string lhs, std::string rhs)
{
auto lhs_ret = std::async(process_question, lhs);
auto rhs_ret = std::async(process_question, rhs);
bool ReturnVal = false;
if (lhs_ret.get().answer == rhs_ret.get().answer)
{
ReturnVal = true;
}
return ReturnVal;
}
我认为需要进行某种舍入,但我不是 100% 确定如何正确完成它。如果这个问题已经得到解决,请原谅我——我通过搜索找不到太多东西。谢谢!
最佳答案
假设 answer
是一个 double
,替换这个
lhs_ret.get().answer == rhs_ret.get().answer
与
abs(lhs_ret.get().answer - rhs_ret.get().answer) < TOL
其中 TOL
是适当的公差值。
float 不应该与 ==
进行比较,而是通过检查绝对差异是否小于给定的公差来进行比较。
有一个难点需要说一下:double的精度大约是16位小数。所以你可以设置 TOL=1.0e-16
。这仅在您的数字小于 1 时有效。对于 16 位数字,这意味着公差必须与 1 一样大。
因此,要么假设您的数字小于 10e8
并使用相对较大的公差,例如 10e-8
,要么您需要做一些更复杂的事情。
关于c++ - 补偿 double/float 不准确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38990695/
我看到以下关于 MPEG 1 运动估计/补偿的解释,只是想知道它是否正确: 为什么我们不直接编码当前 block 和引用 block 之间的原始差异?因为残差的数字通常会小很多。例如,假设一个物体在图
计算机屏幕上像素的亮度通常与像素的数字 RGB 三元组值不线性相关。早期 CRT 的非线性响应需要补偿非线性编码,我们今天仍在继续使用此类编码。 通常我们在计算机屏幕上生成图像并在那里使用它们,所以一
我不知道它叫什么。状态栏?随着接待和电池生命周期的增加。但是有没有一种简单的方法可以判断它是否显示在应用程序中? 我正在编写一些通用代码,如果没有栏,我希望将某些内容放置在屏幕顶部,如果有,则在栏下方
观察下面的简单示例: div { border-bottom: 1px solid black; border-radius: 20%; padding: 10px; } Test 在 S
我有一个这样的嵌套视频: Live camera feed 当用户拍照时,图像沿y轴偏移 Captured Still image 我确实想要捕获整个图像并让用户上下滚动。他们目前可以这样做,但我希望
我从客户端收到了一个字体 (Calibre) 作为 OTF 文件,用于网络应用程序,但文件的“行高”(或者你怎么调用它?)有些奇怪。实际文本溢出顶部的 dom 元素并在下面留下一堆空间,导致各种丑陋。
我编写了一个数学计算器,它从用户那里接收一个字符串并对其进行解析。它使用 double 来保存计算时涉及的所有值。解决后,我将其打印出来,并使用 std::setprecision() 确保其输出正确
不同的 Android 设备具有不同的屏幕尺寸和屏幕密度。编写视频游戏时,补偿差异的好方法是什么? 最佳答案 我们先从 Android 的文档开始 Supporting Multiple Screen
我正在制作个人资料图片裁剪编辑器,它允许在区域内拖动、缩放和旋转图像。 图片的拖动是通过捕捉区域的mousedown和mousemove事件,计算区域内游标开始和停止的x/y坐标,得到游标移动的距离。
我正在尝试按地理区域对 AnyLogic GISRegions 集合进行排序。所述面积是使用GISRegion.area(units)计算的,这很简单。然而,我使用的区域是城市规模的,并且该方法返回一
首先,我希望这不是重复的。我读过很多类似的问题,但找不到与此特定问题相关的问题。 我有一个 javascript 日期选择器,它在内部使用 javascript 日期,这会产生意想不到的副作用。当我选
您可以在此处查看实时版本:http://steffiwilson.com/test . IE9 没有将内容 block 居中。 (我很确定旧版本的 IE 也不能正常工作,但我不能肯定地说。)我已经确保
我是一名优秀的程序员,十分优秀!