Synced fastlog.h with ardour1 updates.
git-svn-id: svn://localhost/trunk/ardour2@16 d708f5d6-7413-0410-9779-e7cbd77b26cf
This commit is contained in:
parent
45866a0ab0
commit
f9546e5c76
@ -11,14 +11,16 @@ static inline float fast_log2 (float val)
|
||||
/* don't use reinterpret_cast<> because that prevents this
|
||||
from being used by pure C code (for example, GnomeCanvasItems)
|
||||
*/
|
||||
int * const exp_ptr = (int *)(&val);
|
||||
union {float f; int i;} t;
|
||||
t.f = val;
|
||||
int * const exp_ptr = &t.i;
|
||||
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)
|
||||
val = ((-1.0f/3) * t.f + 2) * t.f - 2.0f/3;
|
||||
|
||||
return (val + log_2);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user