NaN 在C++为什么
NaN in C++ why?
我正在尝试实现一个 K-nn 分类器。这个问题的一部分是获取从一个示例到另一个示例的欧几里得距离。我在计算它时遇到了问题,因为sum
最终是 NaN。
问题出在此代码块中:
for(int i=0;i<fdataset.size();i++){
float sum=0;
for(int k=0;k<fdataset[i].size();k++){
if(mask[k]){
sum+=(fdataset[i][k]-example[k])*(fdataset[i][k]-example[k]);
}
}
results[i]=sqrt(sum);
}
fdataset
是vector< vector<float> >
,example
是vector<float>
。应该没有问题。那么,为什么我会遇到这个问题?
谢谢!
最可能的解释是你的数据集被一个或多个 NaN "毒害"。只需要fdataset
或example
阵列中的一个 NaN 即可损坏sum
.
作为调试的辅助工具,您可以使用 std::isnan()
检查每个输入。
更新:正如用户 akavel 在评论中建议的那样,还有其他表达式也可以在 IEEE 754 浮点运算中生成 NaN。维基百科在这里列出了它们。我相信与您的代码相关的操作是:
- 其中一个操作数是 NaN 的操作
-
0 * inf
-
inf - inf
因此,您还应该检查您的输入是否与 std::isinf()
inf
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 为什么在全局范围内使用"extern int a"似乎不行?
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 为什么两个不同的未命名名称空间可以共存于一个cpp文件中
- 为什么会发生堆损坏
- 为什么使用 "this" 指针调用派生成员函数?
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 为什么比较运算符如此快速
- 为什么 Serial.println(<char[]>);返回随机字符?
- 为什么这个运算符<重载函数对 STL 算法不可见?
- 为什么不;名字在地图上是按顺序排列的吗
- 我的字符计数代码计算错误.为什么
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 为什么野牛仍在使用"int yylex(void)",却找不到"int yylex(YYS
- 为什么 std::unique 不调用 std::sort?
- 既然存在危险,为什么项目要使用-I include开关
- 为什么在运行时没有向我们提供有关分段错误的更多信息?