[FFmpeg-cvslog] r13604 - trunk/libavcodec/ra144.c
vitor
subversion
Sun Jun 1 21:30:07 CEST 2008
Author: vitor
Date: Sun Jun 1 21:30:07 2008
New Revision: 13604
Log:
The function dec1() do two completly unrelated things. Split the rms calculation out of it.
Modified:
trunk/libavcodec/ra144.c
Modified: trunk/libavcodec/ra144.c
==============================================================================
--- trunk/libavcodec/ra144.c (original)
+++ trunk/libavcodec/ra144.c Sun Jun 1 21:30:07 2008
@@ -239,14 +239,12 @@ static void do_output_subblock(RA144Cont
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, int
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(AVCodecCon
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++) {
More information about the ffmpeg-cvslog
mailing list