shithub: opus

Download patch

ref: 0da0d91ba7871e462933d953124da08b7081a156
parent: 3a9699ee9496765c9ffd450e3685044d548c58ab
author: Jean-Marc Valin <[email protected]>
date: Thu Jun 17 03:32:20 EDT 2010

fixed-point: PLC auto-correlation converted

--- a/libcelt/plc.c
+++ b/libcelt/plc.c
@@ -137,33 +137,37 @@
                    int          n
                   )
 {
-   float d;
+   celt_word32 d;
    int i;
-   float scale=1;
-   VARDECL(float, xx);
+   VARDECL(celt_word16, xx);
    SAVE_STACK;
-   ALLOC(xx, n, float);
+   ALLOC(xx, n, celt_word16);
    for (i=0;i<n;i++)
       xx[i] = x[i];
    for (i=0;i<overlap;i++)
    {
-      xx[i] *= (1./Q15ONE)*window[i];
-      xx[n-i-1] *= (1./Q15ONE)*window[i];
+      xx[i] = MULT16_16_Q15(x[i],window[i]);
+      xx[n-i-1] = MULT16_16_Q15(x[n-i-1],window[i]);
    }
 #ifdef FIXED_POINT
    {
       float ac0=0;
+      int shift;
       for(i=0;i<n;i++)
-         ac0 += x[i]*x[i];
-      ac0+=10;
-      scale = 2000000000/ac0;
+         ac0 += SHR32(MULT16_16(xx[i],xx[i]),8);
+      ac0 += 1+n;
+
+      shift = celt_ilog2(ac0)-30+8;
+      shift = (shift+1)/2;
+      for(i=0;i<n;i++)
+         xx[i] = VSHR32(xx[i], shift);
    }
 #endif
    while (lag>=0)
    {
       for (i = lag, d = 0; i < n; i++) 
-         d += x[i] * x[i-lag];
-      ac[lag] = d*scale;
+         d += xx[i] * xx[i-lag];
+      ac[lag] = d;
       /*printf ("%f ", ac[lag]);*/
       lag--;
    }