| Index: third_party/opus/src/silk/NLSF_decode.c
|
| diff --git a/third_party/opus/src/silk/NLSF_decode.c b/third_party/opus/src/silk/NLSF_decode.c
|
| index 9f715060b8efb2c3c6d84c10edc68036f0253f46..eeb0ba8c92c8b60f7dc61953fd8054e874ba07d2 100644
|
| --- a/third_party/opus/src/silk/NLSF_decode.c
|
| +++ b/third_party/opus/src/silk/NLSF_decode.c
|
| @@ -32,7 +32,7 @@ POSSIBILITY OF SUCH DAMAGE.
|
| #include "main.h"
|
|
|
| /* Predictive dequantizer for NLSF residuals */
|
| -static OPUS_INLINE void silk_NLSF_residual_dequant( /* O Returns RD value in Q30 */
|
| +static OPUS_INLINE void silk_NLSF_residual_dequant( /* O Returns RD value in Q30 */
|
| opus_int16 x_Q10[], /* O Output [ order ] */
|
| const opus_int8 indices[], /* I Quantization indices [ order ] */
|
| const opus_uint8 pred_coef_Q8[], /* I Backward predictor coefs [ order ] */
|
| @@ -70,15 +70,9 @@ void silk_NLSF_decode(
|
| opus_uint8 pred_Q8[ MAX_LPC_ORDER ];
|
| opus_int16 ec_ix[ MAX_LPC_ORDER ];
|
| opus_int16 res_Q10[ MAX_LPC_ORDER ];
|
| - opus_int16 W_tmp_QW[ MAX_LPC_ORDER ];
|
| - opus_int32 W_tmp_Q9, NLSF_Q15_tmp;
|
| + opus_int32 NLSF_Q15_tmp;
|
| const opus_uint8 *pCB_element;
|
| -
|
| - /* Decode first stage */
|
| - pCB_element = &psNLSF_CB->CB1_NLSF_Q8[ NLSFIndices[ 0 ] * psNLSF_CB->order ];
|
| - for( i = 0; i < psNLSF_CB->order; i++ ) {
|
| - pNLSF_Q15[ i ] = silk_LSHIFT( (opus_int16)pCB_element[ i ], 7 );
|
| - }
|
| + const opus_int16 *pCB_Wght_Q9;
|
|
|
| /* Unpack entropy table indices and predictor for current CB1 index */
|
| silk_NLSF_unpack( ec_ix, pred_Q8, psNLSF_CB, NLSFIndices[ 0 ] );
|
| @@ -86,13 +80,11 @@ void silk_NLSF_decode(
|
| /* Predictive residual dequantizer */
|
| silk_NLSF_residual_dequant( res_Q10, &NLSFIndices[ 1 ], pred_Q8, psNLSF_CB->quantStepSize_Q16, psNLSF_CB->order );
|
|
|
| - /* Weights from codebook vector */
|
| - silk_NLSF_VQ_weights_laroia( W_tmp_QW, pNLSF_Q15, psNLSF_CB->order );
|
| -
|
| - /* Apply inverse square-rooted weights and add to output */
|
| + /* Apply inverse square-rooted weights to first stage and add to output */
|
| + pCB_element = &psNLSF_CB->CB1_NLSF_Q8[ NLSFIndices[ 0 ] * psNLSF_CB->order ];
|
| + pCB_Wght_Q9 = &psNLSF_CB->CB1_Wght_Q9[ NLSFIndices[ 0 ] * psNLSF_CB->order ];
|
| for( i = 0; i < psNLSF_CB->order; i++ ) {
|
| - W_tmp_Q9 = silk_SQRT_APPROX( silk_LSHIFT( (opus_int32)W_tmp_QW[ i ], 18 - NLSF_W_Q ) );
|
| - NLSF_Q15_tmp = silk_ADD32( pNLSF_Q15[ i ], silk_DIV32_16( silk_LSHIFT( (opus_int32)res_Q10[ i ], 14 ), W_tmp_Q9 ) );
|
| + NLSF_Q15_tmp = silk_ADD_LSHIFT32( silk_DIV32_16( silk_LSHIFT( (opus_int32)res_Q10[ i ], 14 ), pCB_Wght_Q9[ i ] ), (opus_int16)pCB_element[ i ], 7 );
|
| pNLSF_Q15[ i ] = (opus_int16)silk_LIMIT( NLSF_Q15_tmp, 0, 32767 );
|
| }
|
|
|
|
|