[FFmpeg-cvslog] r12856 - trunk/libavcodec/nellymoserdec.c
michael
subversion
Wed Apr 16 17:28:11 CEST 2008
Author: michael
Date: Wed Apr 16 17:28:11 2008
New Revision: 12856
Log:
Move scale_bias to a more sane place. I am starting to wonder how this
trash got into svn ...
Modified:
trunk/libavcodec/nellymoserdec.c
Modified: trunk/libavcodec/nellymoserdec.c
==============================================================================
--- trunk/libavcodec/nellymoserdec.c (original)
+++ trunk/libavcodec/nellymoserdec.c Wed Apr 16 17:28:11 2008
@@ -96,7 +96,7 @@ typedef struct NellyMoserDecodeContext {
AVRandomState random_state;
GetBitContext gb;
int add_bias;
- int scale_bias;
+ float scale_bias;
DSPContext dsp;
MDCTContext imdct_ctx;
DECLARE_ALIGNED_16(float,imdct_tmp[NELLY_BUF_LEN]);
@@ -120,7 +120,7 @@ static void overlap_and_window(NellyMose
top = NELLY_BUF_LEN-1;
while (bot < NELLY_BUF_LEN) {
- audio[bot] = ( a_in[bot]*sine_window[bot]+state[bot]*sine_window[top])/s->scale_bias + s->add_bias;
+ audio[bot] = a_in[bot]*sine_window[bot]+state[bot]*sine_window[top] + s->add_bias;
bot++;
top--;
@@ -279,7 +279,7 @@ void nelly_decode_block(NellyMoserDecode
for (i=0 ; i<NELLY_BANDS ; i++) {
if (i > 0)
val += nelly_delta_table[get_bits(&s->gb, 5)];
- pval = pow(2, val/2048);
+ pval = pow(2, val/2048) * s->scale_bias;
for (j = 0; j < nelly_band_sizes_table[i]; j++) {
*bptr++ = val;
*pptr++ = pval;
@@ -328,10 +328,10 @@ static av_cold int decode_init(AVCodecCo
if(s->dsp.float_to_int16 == ff_float_to_int16_c) {
s->add_bias = 385;
- s->scale_bias = 8*32768;
+ s->scale_bias = 1.0/(8*32768);
} else {
s->add_bias = 0;
- s->scale_bias = 1*8;
+ s->scale_bias = 1.0/(1*8);
}
/* Generate overlap window */
More information about the ffmpeg-cvslog
mailing list