]> rtime.felk.cvut.cz Git - frescor/ffmpeg.git/commitdiff
Simplify interp()
authorvitor <vitor@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Tue, 24 Jun 2008 21:32:34 +0000 (21:32 +0000)
committervitor <vitor@9553f0bf-9b14-0410-a0b8-cfaf0461ba5b>
Tue, 24 Jun 2008 21:32:34 +0000 (21:32 +0000)
git-svn-id: file:///var/local/repositories/ffmpeg/trunk@13953 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b

libavcodec/ra144.c

index d880c43edcea2bce462a9898b1486496c13708cc..4e0b2c7a9a901f92a606965f5c5956a4826235b7 100644 (file)
@@ -301,7 +301,7 @@ static int eval_refl(int *refl, const int16_t *coefs, RA144Context *ractx)
 }
 
 static int interp(RA144Context *ractx, int16_t *out, int block_num,
-                  int copynew, int energy)
+                  int copyold, int energy)
 {
     int work[10];
     int a = block_num + 1;
@@ -316,13 +316,8 @@ static int interp(RA144Context *ractx, int16_t *out, int block_num,
     if (eval_refl(work, out, ractx)) {
         // The interpolated coefficients are unstable, copy either new or old
         // coefficients
-        if (copynew) {
-            int_to_int16(out, ractx->lpc_coef[0]);
-            return rescale_rms(ractx->lpc_refl_rms[0], energy);
-        } else {
-            int_to_int16(out, ractx->lpc_coef[1]);
-            return rescale_rms(ractx->lpc_refl_rms[1], energy);
-        }
+        int_to_int16(out, ractx->lpc_coef[copyold]);
+        return rescale_rms(ractx->lpc_refl_rms[copyold], energy);
     } else {
         return rescale_rms(rms(work), energy);
     }
@@ -359,10 +354,10 @@ static int ra144_decode_frame(AVCodecContext * avctx, void *vdata,
 
     energy = energy_tab[get_bits(&gb, 5)];
 
-    refl_rms[0] = interp(ractx, block_coefs[0], 0, 0, ractx->old_energy);
-    refl_rms[1] = interp(ractx, block_coefs[1], 1, energy > ractx->old_energy,
+    refl_rms[0] = interp(ractx, block_coefs[0], 0, 1, ractx->old_energy);
+    refl_rms[1] = interp(ractx, block_coefs[1], 1, energy <= ractx->old_energy,
                     t_sqrt(energy*ractx->old_energy) >> 12);
-    refl_rms[2] = interp(ractx, block_coefs[2], 2, 1, energy);
+    refl_rms[2] = interp(ractx, block_coefs[2], 2, 0, energy);
     refl_rms[3] = rescale_rms(ractx->lpc_refl_rms[0], energy);
 
     int_to_int16(block_coefs[3], ractx->lpc_coef[0]);