diff options
author | Jean-Marc Valin <jmvalin@jmvalin.ca> | 2016-04-22 16:13:46 -0400 |
---|---|---|
committer | Jean-Marc Valin <jmvalin@jmvalin.ca> | 2016-07-17 15:05:54 -0400 |
commit | ecfdb2862ab8b4e8ef188127f1c12c56f23996a1 (patch) | |
tree | b927765c2fa3cb2f9949f99154c382905e88baa3 | |
parent | d68e809bf8310e215c47bc334edb7d9207ed1bc5 (diff) | |
download | opus-ecfdb2862ab8b4e8ef188127f1c12c56f23996a1.tar.gz |
Re-enabling high-band attenuation for hybrid mode
The new attenuation is much smaller than previously.
-rw-r--r-- | src/opus_encoder.c | 6 |
1 files changed, 1 insertions, 5 deletions
diff --git a/src/opus_encoder.c b/src/opus_encoder.c index 85295abb..c273cd6a 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 */ |