浮点错误
Floating Point Error
本文关键字:错误 更新时间:2023-10-16
我的C++代码中有一个奇怪的错误:
float cosTheta = someFunction();
cout << cosTheta << endl; // prints 1 on the console
if (cosTheta == 1) { // doesn't enter this condition
cout << "it is 1" << endl;
}
float sinTheta = sqrt(1 - pow(cosTheta, 2));
return (someVariable * sinTheta);
问题是:cosTheta 是 1,但它没有进入条件,尽管它在屏幕上打印 1。当我打印返回的值时,它应该是 0,因为 cosTheta 是 1,所以 sinTheta 得到 0,返回值得到 0,但我得到 0.0953562...
我在 Java 中测试了相同的代码,结果得到 0。
您不应该将浮点数与 ==
进行比较。浮点运算中的舍入误差意味着您应该选择一个精度EPSILON
(适合您的情况)并像这样使用它:
const float EPSILON = 0.00001;
if( fabs(cosTheta - 1) < EPSILON ) {
cout << "It is approximately 1n";
}
相关文章:
- 警告处理为错误这里有什么问题
- "error: no matching function for call to"构造函数错误
- boost::进程间消息队列引发错误
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- QT在错误的班级中寻找空位
- vector.resize()中的分配错误
- 代码在main()中运行,但在函数中出现错误
- 释放错误后堆使用
- (C++)分析树以计算返回错误值的简单算术表达式
- Project Euler问题4的错误解决方案
- 我的字符计数代码计算错误.为什么
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 在某些循环内使用vector.push_back时出现分段错误
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 错误:未在此范围内声明'reverse'