diff --git a/celt/arch.h b/celt/arch.h index feab0facde0650ba1195e59d1cbf5c25e3969cce..e497a4d92a88d72124a87308fe096b972c1391b0 100644 --- a/celt/arch.h +++ b/celt/arch.h @@ -100,6 +100,7 @@ typedef opus_val32 celt_ener; #define DB_SHIFT 10 #define EPSILON 1 +#define VERY_SMALL 0 #define VERY_LARGE16 ((opus_val16)32767) #define Q15_ONE ((opus_val16)32767) @@ -140,6 +141,7 @@ typedef float celt_ener; #define NORM_SCALING 1.f #define EPSILON 1e-15f +#define VERY_SMALL 1e-30f #define VERY_LARGE16 1e15f #define Q15_ONE ((opus_val16)1.f) diff --git a/celt/celt_decoder.c b/celt/celt_decoder.c index 01f2868d973e75c7aa6064de2b66ad2bdc8c55d7..4424b97098788dcba437b431a4f941b1ed02d4d6 100644 --- a/celt/celt_decoder.c +++ b/celt/celt_decoder.c @@ -236,7 +236,7 @@ void deemphasis(celt_sig *in[], opus_val16 *pcm, int N, int C, int downsample, c /* Shortcut for the standard (non-custom modes) case */ for (j=0;j<N;j++) { - celt_sig tmp = x[j] + m; + celt_sig tmp = x[j] + m + VERY_SMALL; m = MULT16_32_Q15(coef0, tmp); y[j*C] = SCALEOUT(SIG2WORD16(tmp)); } diff --git a/src/opus_encoder.c b/src/opus_encoder.c index cb7159c826cf2ae917b1b3e0c4e1a05c21d87653..5c74535e4c8076bba3aaf51c34fe09247335d901 100644 --- a/src/opus_encoder.c +++ b/src/opus_encoder.c @@ -429,10 +429,10 @@ static void dc_reject(const opus_val16 *in, opus_int32 cutoff_Hz, opus_val16 *ou x = in[channels*i+c]; /* First stage */ tmp = x-hp_mem[2*c]; - hp_mem[2*c] = hp_mem[2*c] + coef*(x - hp_mem[2*c]); + hp_mem[2*c] = hp_mem[2*c] + coef*(x - hp_mem[2*c]) + VERY_SMALL; /* Second stage */ y = tmp - hp_mem[2*c+1]; - hp_mem[2*c+1] = hp_mem[2*c+1] + coef*(tmp - hp_mem[2*c+1]); + hp_mem[2*c+1] = hp_mem[2*c+1] + coef*(tmp - hp_mem[2*c+1]) + VERY_SMALL; out[channels*i+c] = y; } }