可怕的数字不知从何而来

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因为您将在双精度算术中使用它。