From ecfdb2862ab8b4e8ef188127f1c12c56f23996a1 Mon Sep 17 00:00:00 2001
From: Jean-Marc Valin <jmvalin@jmvalin.ca>
Date: Fri, 22 Apr 2016 16:13:46 -0400
Subject: [PATCH] Re-enabling high-band attenuation for hybrid mode

The new attenuation is much smaller than previously.
---
 src/opus_encoder.c | 6 +-----
 1 file changed, 1 insertion(+), 5 deletions(-)

diff --git a/src/opus_encoder.c b/src/opus_encoder.c
index 85295abb1..c273cd6a2 100644
--- a/src/opus_encoder.c
+++ b/src/opus_encoder.c
@@ -1545,7 +1545,6 @@ opus_int32 opus_encode_native(OpusEncoder *st, const opus_val16 *pcm, int frame_
         /* Distribute bits between SILK and CELT */
         total_bitRate = 8 * bytes_target * frame_rate;
         if( st->mode == MODE_HYBRID ) {
-            int HB_gain_ref;
             /* Base rate for SILK */
             st->silk_mode.bitRate = compute_silk_rate_for_hybrid(total_bitRate,
                   curr_bandwidth, st->Fs == 50 * frame_size, st->use_vbr);
@@ -1553,10 +1552,7 @@ opus_int32 opus_encode_native(OpusEncoder *st, const opus_val16 *pcm, int frame_
             {
                /* Increasingly attenuate high band when it gets allocated fewer bits */
                celt_rate = total_bitRate - st->silk_mode.bitRate;
-               HB_gain_ref = (curr_bandwidth == OPUS_BANDWIDTH_SUPERWIDEBAND) ? 3000 : 3600;
-               HB_gain = SHL32((opus_val32)celt_rate, 9) / SHR32((opus_val32)celt_rate + st->stream_channels * HB_gain_ref, 6);
-               HB_gain = HB_gain < (opus_val32)Q15ONE*6/7 ? HB_gain + Q15ONE/7 : Q15ONE;
-               HB_gain = Q15ONE;
+               HB_gain = Q15ONE - SHR32(celt_exp2(-celt_rate * QCONST16(1.f/1024, 10)), 1);
             }
         } else {
             /* SILK gets all bits */
-- 
GitLab