diff --git a/apps/codecs/libwma/mdct.c b/apps/codecs/libwma/mdct.c index ac30def6dd..838bda47a7 100644 --- a/apps/codecs/libwma/mdct.c +++ b/apps/codecs/libwma/mdct.c @@ -22,10 +22,7 @@ #include "wmafixed.h" #include "fft.h" -fixed32 *tcosarray[5], *tsinarray[5]; -fixed32 tcos0[1024], tcos1[512], tcos2[256], tcos3[128], tcos4[64]; //these are the sin and cos rotations used by the MDCT -fixed32 tsin0[1024], tsin1[512], tsin2[256], tsin3[128], tsin4[64]; - +fixed32 tcos0[1024], tsin0[1024]; //these are the sin and cos rotations used by the MDCT uint16_t revtab0[1024]; /** @@ -33,32 +30,16 @@ uint16_t revtab0[1024]; */ int ff_mdct_init(MDCTContext *s, int nbits, int inverse) { - int n, n4, i; + int n; // fixed32 alpha; - memset(s, 0, sizeof(*s)); n = 1 << nbits; //nbits ranges from 12 to 8 inclusive + s->nbits = nbits; s->n = n; - n4 = n >> 2; - s->tcos = tcosarray[12-nbits]; - s->tsin = tsinarray[12-nbits]; - for(i=0;i> nbits; - //ip = fixdiv32(ip,itofix32(n)); // PJJ optimize - //alpha = fixmul32(TWO_M_PI_F, ip); - //s->tcos[i] = -fixcos32(alpha); //alpha between 0 and pi/2 - //s->tsin[i] = -fixsin32(alpha); - s->tsin[i] = - fsincos(ip<<16, &(s->tcos[i])); //I can't remember why this works, but it seems to agree for ~24 bits, maybe more! - s->tcos[i] *=-1; - } (&s->fft)->nbits = nbits-2; - (&s->fft)->inverse = inverse; return 0; @@ -76,8 +57,6 @@ void ff_imdct_calc(MDCTContext *s, fixed32 *input) { int k, n8, n4, n2, n, j,scale; - const fixed32 *tcos = s->tcos; - const fixed32 *tsin = s->tsin; const fixed32 *in1, *in2; FFTComplex *z1 = (FFTComplex *)output; FFTComplex *z2 = (FFTComplex *)input; @@ -96,19 +75,21 @@ void ff_imdct_calc(MDCTContext *s, for(k = 0; k < n4; k++) { - j=revtab0[k<fft, z1); + scale = fft_calc_unscaled(&s->fft, z1); /* post rotation + reordering */ for(k = 0; k < n4; k++) { - CMUL(&z2[k].re, &z2[k].im, (z1[k].re), (z1[k].im), tcos[k], tsin[k]); + int kshift = k<> 12; + //ip = fixdiv32(ip,itofix32(n)); // PJJ optimize + //alpha = fixmul32(TWO_M_PI_F, ip); + //s->tcos[i] = -fixcos32(alpha); //alpha between 0 and pi/2 + //s->tsin[i] = -fixsin32(alpha); + + //I can't remember why this works, but it seems to agree for ~24 bits, maybe more! + tsin0[i] = - fsincos(ip<<16, &(tcos0[i])); + tcos0[i] *=-1; + } + fft_init_global(); return 0;