diff options
author | Vitor Sessak <vitor1001@gmail.com> | 2008-06-01 19:30:07 +0000 |
---|---|---|
committer | Vitor Sessak <vitor1001@gmail.com> | 2008-06-01 19:30:07 +0000 |
commit | 50b8f2cf1cefc7f8938528b8fc71a5fcfaba67f1 (patch) | |
tree | e5398265451a84644df9dcdf7f0285c1adf103fc /libavcodec/ra144.c | |
parent | ce3d365f2f9e554ba12569553a796b3f492d0de5 (diff) | |
download | ffmpeg-50b8f2cf1cefc7f8938528b8fc71a5fcfaba67f1.tar.gz |
The function dec1() do two completly unrelated things. Split the rms calculation out of it.
Originally committed as revision 13604 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/ra144.c')
-rw-r--r-- | libavcodec/ra144.c | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/libavcodec/ra144.c b/libavcodec/ra144.c index 42be927d51..17bbcc5434 100644 --- a/libavcodec/ra144.c +++ b/libavcodec/ra144.c @@ -239,14 +239,12 @@ static void do_output_subblock(RA144Context *ractx, final(lpc_coefs, block, output_buffer, ractx->buffer, BLOCKSIZE); } -static int dec1(int16_t *decsp, const int *data, const int *inp, int f) +static void dec1(int16_t *decsp, const int *inp) { int i; for (i=0; i<30; i++) *(decsp++) = *(inp++); - - return rms(data, f); } /** @@ -315,10 +313,13 @@ static int dec2(RA144Context *ractx, int16_t *decsp, int block_num, if (eval_refl(decsp, work)) { // The interpolated coefficients are unstable, copy either new or old // coefficients - if (copynew) - return dec1(decsp, ractx->lpc_refl, ractx->lpc_coef, f); - else - return dec1(decsp, ractx->lpc_refl_old, ractx->lpc_coef_old, f); + if (copynew) { + dec1(decsp, ractx->lpc_coef); + return rms(ractx->lpc_refl, f); + } else { + dec1(decsp, ractx->lpc_coef_old); + return rms(ractx->lpc_refl_old, f); + } } else { return rms(work, f); } @@ -358,8 +359,9 @@ static int ra144_decode_frame(AVCodecContext * avctx, refl_rms[1] = dec2(ractx, block_coefs[1], 1, energy > ractx->old_energy, t_sqrt(energy*ractx->old_energy) >> 12); refl_rms[2] = dec2(ractx, block_coefs[2], 2, 1, energy); - refl_rms[3] = dec1(block_coefs[3], ractx->lpc_refl, ractx->lpc_coef, - energy); + refl_rms[3] = rms(ractx->lpc_refl, energy); + + dec1(block_coefs[3], ractx->lpc_coef); /* do output */ for (c=0; c<4; c++) { |