/* * Copyright (c) 2011-2019 Belledonne Communications SARL. * * This file is part of bcg729. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "typedef.h" #include "codecParameters.h" #include "basicOperationsMacros.h" #include "utils.h" #include "computeWeightedSpeech.h" /*****************************************************************************/ /* computeWeightedSpeech: compute wieghted speech according to spec A3.3.3 */ /* parameters: */ /* -(i) inputSignal : 90 values buffer accessed in range [-10, 79] in Q0*/ /* -(i) qLPCoefficients: 20 coefficients(10 for each subframe) in Q12 */ /* -(i) weightedqLPCoefficients: 20 coefficients(10 for each subframe) */ /* in Q12 */ /* -(i/o) weightedInputSignal: 90 values in Q0: [-10, -1] as input */ /* [0,79] as output in Q0 */ /* -(o) LPResidualSignal: 80 values of residual signal in Q0 */ /* */ /*****************************************************************************/ void computeWeightedSpeech(word16_t inputSignal[], word16_t qLPCoefficients[], word16_t weightedqLPCoefficients[], word16_t weightedInputSignal[], word16_t LPResidualSignal[]) { /* algo as specified in A3.3.3: */ /* first compute LPResidualSignal[n] = inputSignal[n] + ∑(i=1..10)qLP[i]*inputSignal[n-i] specA3.3.3 eqA.3 */ /* then compute qLP' coefficients as qLP'[i] = weightedqLP[i] - 0.7*weightedqLP[i-1] */ /* finally get the weightedInputSignal[n] = LPResidualSignal[n] - ∑(i=1..10)qLP'[i]*weightedInputSignal[n-i] spec A3.3.3 eqA.2 */ int i,j; word16_t weightedqLPLowPassCoefficients[NB_LSP_COEFF]; /* in Q12 */ /*** compute LPResisualSignal (spec A3.3.3 eqA.3) in Q0 ***/ /* compute residual signal for the first subframe: use the first 10 qLPCoefficients */ for (i=0; i acc in Q12 */ } LPResidualSignal[i] = (word16_t)SATURATE(PSHR(acc, 12), MAXINT16); /* shift back acc to Q0 and saturate it to avoid overflow when going back to 16 bits */ } /* compute residual signal for the second subframe: use the second part of qLPCoefficients */ for (i=L_SUBFRAME; i acc in Q12 */ } LPResidualSignal[i] = (word16_t)SATURATE(PSHR(acc, 12), MAXINT16); /* shift back acc to Q0 and saturate it to avoid overflow when going back to 16 bits */ } /*** compute weightedqLPLowPassCoefficients and weightedInputSignal for first subframe ***/ /* spec A3.3.3 a' = weightedqLPLowPassCoefficients[i] = weightedqLP[i] - 0.7*weightedqLP[i-1] */ weightedqLPLowPassCoefficients[0] = SUB16(weightedqLPCoefficients[0],O7_IN_Q12); /* weightedqLP[-1] = 1 -> weightedqLPLowPassCoefficients[0] = weightedqLPCoefficients[0] - 0.7 */ for (i=1; i weightedqLPLowPassCoefficients[0] = weightedqLPCoefficients[0] - 0.7 */ for (i=1; i