shithub: opus

Download patch

ref: 039e9ab155f3527e0e4343d7989c26a4e50a271e
parent: 54bddf0f1a83f37cfeb8519627beaa2422a86418
author: Jean-Marc Valin <[email protected]>
date: Wed Sep 11 23:05:43 EDT 2013

Tuning the surround masking

We're now a bit more conservative and only take into account the bands
that are being codec. Also weighting the rate saving by the band width.

--- a/celt/celt_encoder.c
+++ b/celt/celt_encoder.c
@@ -1535,27 +1535,35 @@
    for(i=0;i<st->end;i++)
       surround_dynalloc[i] = 0;
    /* This computes how much masking takes place between surround channels */
-   if (st->energy_mask&&!st->lfe)
+   if (st->start==0&&st->energy_mask&&!st->lfe)
    {
+      int mask_end;
       opus_val32 mask_avg=0;
       opus_val32 diff=0;
+      int count=0;
+      mask_end = st->lastCodedBands;
       for (c=0;c<C;c++)
       {
-         for(i=0;i<st->end;i++)
+         for(i=0;i<mask_end;i++)
          {
-            mask_avg += st->energy_mask[nbEBands*c+i];
-            diff += st->energy_mask[i+c*nbEBands]*(opus_int32)(1+2*i-st->end);
+            mask_avg += st->energy_mask[nbEBands*c+i]*(eBands[i+1]-eBands[i]);
+            count += (eBands[i+1]-eBands[i]);
+            diff += st->energy_mask[i+c*nbEBands]*(opus_int32)(1+2*i-mask_end);
          }
       }
-      mask_avg = DIV32_16(mask_avg,C*st->end);
+      mask_avg = DIV32_16(mask_avg,count);
+      /* Just being conservative here */
+      mask_avg -= HALF32(HALF32(mask_avg));
       mask_avg = MAX16(mask_avg, -QCONST16(2.f, DB_SHIFT));
-      diff = diff*6/(C*(st->end-1)*(st->end+1)*st->end);
-      diff = MAX32(MIN32(diff, QCONST32(.05f, DB_SHIFT)), -QCONST32(.05f, DB_SHIFT));
-      for(i=0;i<st->end;i++)
+      diff = diff*6/(C*(mask_end-1)*(mask_end+1)*mask_end);
+      /* Again, being conservative */
+      diff = HALF32(diff);
+      diff = MAX32(MIN32(diff, QCONST32(.031f, DB_SHIFT)), -QCONST32(.031f, DB_SHIFT));
+      for(i=0;i<mask_end;i++)
       {
          opus_val32 lin;
          opus_val16 unmask;
-         lin = mask_avg + HALF32(diff*(1+2*i-st->end));
+         lin = mask_avg + HALF32(diff*(1+2*i-mask_end));
          if (C==2)
             unmask = MAX16(st->energy_mask[i], st->energy_mask[nbEBands+i]) - lin;
          else