diff --git a/celt/tests/test_unit_mathops.c b/celt/tests/test_unit_mathops.c index 8119bc1ef30ed141fe1a89984fbd6cc04c11b656..9673de6c7565d5d1e8e3b8fd7e563fb7a76f9b37 100644 --- a/celt/tests/test_unit_mathops.c +++ b/celt/tests/test_unit_mathops.c @@ -209,10 +209,17 @@ void testilog2(void) opus_val32 x; for (x=1;x<=268435455;x+=127) { - opus_val32 error = abs(celt_ilog2(x)-(int)floor(log2(x))); - if (error!=0) + opus_val32 lg = celt_ilog2(x); + if (lg<0 || lg>=31) { - printf("celt_ilog2 failed: celt_ilog2(x)!=floor(log2(x)) (x = %d, error = %d)\n",x,error); + printf("celt_ilog2 failed: 0<=celt_ilog2(x)<31 (x = %d, celt_ilog2(x) = %d)\n",x,lg); + ret = 1; + } + opus_val32 y = 1<<lg; + + if (x<y || (x>>1)>=y) + { + printf("celt_ilog2 failed: 2**celt_ilog2(x)<=x<2**(celt_ilog2(x)+1) (x = %d, 2**celt_ilog2(x) = %d)\n",x,y); ret = 1; } }