Commit b18ac711 authored by reimar's avatar reimar

Partially revert r20233, exp2f is not available on some BSDs, DOS and AVR32.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@20240 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent be1afadb
...@@ -411,7 +411,7 @@ static av_cold int decode_init(AVCodecContext * avctx) ...@@ -411,7 +411,7 @@ static av_cold int decode_init(AVCodecContext * avctx)
double value = i/4; double value = i/4;
double f, fm; double f, fm;
int e, m; int e, m;
f = value * cbrtf(value) * exp2f((i&3)*0.25); f = value * cbrtf(value) * pow(2, (i&3)*0.25);
fm = frexp(f, &e); fm = frexp(f, &e);
m = (uint32_t)(fm*(1LL<<31) + 0.5); m = (uint32_t)(fm*(1LL<<31) + 0.5);
e+= FRAC_BITS - 31 + 5 - 100; e+= FRAC_BITS - 31 + 5 - 100;
...@@ -423,7 +423,7 @@ static av_cold int decode_init(AVCodecContext * avctx) ...@@ -423,7 +423,7 @@ static av_cold int decode_init(AVCodecContext * avctx)
for(i=0; i<512*16; i++){ for(i=0; i<512*16; i++){
double value = i & 15; double value = i & 15;
int exponent= (i>>4); int exponent= (i>>4);
double f= value * cbrtf(value) * exp2f((exponent-400)*0.25 + FRAC_BITS + 5); double f= value * cbrtf(value) * pow(2, (exponent-400)*0.25 + FRAC_BITS + 5);
expval_table[exponent][i&15]= llrint(f); expval_table[exponent][i&15]= llrint(f);
if((i&15)==1) if((i&15)==1)
exp_table[exponent]= llrint(f); exp_table[exponent]= llrint(f);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment