可怕的数字不知从何而来
Horrible number comes from nowhere
本文关键字:数字 更新时间:2023-10-16
我突然得到了这个函数相当大的结果......应该很简单,但现在看不出来。
double prob_calculator_t::pimpl_t::B_full_term() const
{
double result = 0.0;
for (uint32_t j=0, j_end=U; j<j_end; j++)
{
uint32_t inhabited_columns = doc->row_sums[j];
// DEBUG
cout << "inhabited_columns: " << inhabited_columns << endl;
cout << "log_of_sum[j]: " << log_of_sum[j] << endl;
cout << "sum_of_log[j]: " << sum_of_log[j] << endl;
// end DEBUG
result += ( -inhabited_columns * log( log_of_sum[j] ) + sum_of_log[ j ] );
cout << "result: " << result << endl;
}
return result;
}
痕迹在哪里:
inhabited_columns: 1
log_of_sum[j]: 110.56
sum_of_log[j]: -2.81341
result: 2.02102e+10
inhabited_columns: 42
log_of_sum[j]: 110.56
sum_of_log[j]: -143.064
result: 4.04204e+10
感谢您的帮助!
inhabited_columns
是无符号的,我看到它前面有一个一元-
:-inhabited_columns
.
(请注意,一元-
具有非常高的运算符优先级;高于*
等)。
这就是你的问题所在!引用迈克·西摩的回答:
当你否定它时,结果仍然是无符号的;值会减小 模 232 给出一个大的正值。
一种解决方法是编写
-(inhabited_columns * log(log_of_sum[j]))
因此,否定将在浮点中进行
inhabited_columns
是无符号类型。当你否定它时,结果仍然是未签名的;该值被减模 232 以给出较大的正值。
您应该将其更改为足够大的有符号类型(如果您不会有超过几十亿列,则可能int32_t
),或者double
因为您将在双精度算术中使用它。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 检查输入是否不是整数或数字
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- 如何用数字处理log(0)
- 最高有效数字侧的第N位
- 如何获取一个数字的前3位
- 查找最接近的大于当前数字的数字的索引
- 找到两对数字,使它们的乘积的绝对差最小化
- 我想做一个彼此不同但重复出现的数字
- 将数字转换为字母(例如:123 转换为一二三)
- C++如何计算用户输入的数字中的偶数位数
- 如何在C++中确定文本文件中的元素是字符还是数字
- 打印数字图案
- C++问题:用户认为数字1-100,程序提出问题不超过6次即可得到答案。无法正确
- 如何检查一个c++字符串中有多少相同的字符/数字
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 将数字打印成文字
- 当使用比格式支持的精度更高的精度来显示数字时,会写出什么数据
- 在将数字随机生成为数组期间从内存输出随机数的数组