谁能详细给我解释一下这个功能的log 2是如何工作的:我在需要浮点专家
inline float fast_log2 (float val)
{
int * const exp_ptr = reinterpret_cast <int *> (&val);
int x = *exp_ptr;
const int log_2 = ((x >> 23) & 255) - 128;
x &= ~(255 << 23);
x += 127 << 23;
*exp_ptr = x;
val = ((-1.0f/3) * val + 2) * val - 2.0f/3; // (1)
return (val + log_2);
}
-128而不是-127得到E^2而不是E? – Skeen 2010-12-16 14:20:31
@Skeen:呃,当然是2^E,而不是E^2 – 2010-12-16 14:23:54
哦。<,我在阅读失败,请不要杀了我! :O,但为什么它是-128而不是-127呢? – Skeen 2010-12-16 14:25:41