1 /*
2  *  Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3  *
4  *  Use of this source code is governed by a BSD-style license
5  *  that can be found in the LICENSE file in the root of the source
6  *  tree. An additional intellectual property rights grant can be found
7  *  in the file PATENTS.  All contributing project authors may
8  *  be found in the AUTHORS file in the root of the source tree.
9  */
10 
11 /******************************************************************
12 
13  iLBC Speech Coder ANSI-C Source Code
14 
15  WebRtcIlbcfix_CbUpdateBestIndex.c
16 
17 ******************************************************************/
18 
19 #include "modules/audio_coding/codecs/ilbc/defines.h"
20 #include "modules/audio_coding/codecs/ilbc/cb_update_best_index.h"
21 #include "modules/audio_coding/codecs/ilbc/constants.h"
22 
WebRtcIlbcfix_CbUpdateBestIndex(int32_t CritNew,int16_t CritNewSh,size_t IndexNew,int32_t cDotNew,int16_t invEnergyNew,int16_t energyShiftNew,int32_t * CritMax,int16_t * shTotMax,size_t * bestIndex,int16_t * bestGain)23 void WebRtcIlbcfix_CbUpdateBestIndex(
24     int32_t CritNew,    /* (i) New Potentially best Criteria */
25     int16_t CritNewSh,   /* (i) Shift value of above Criteria */
26     size_t IndexNew,   /* (i) Index of new Criteria */
27     int32_t cDotNew,    /* (i) Cross dot of new index */
28     int16_t invEnergyNew,  /* (i) Inversed energy new index */
29     int16_t energyShiftNew,  /* (i) Energy shifts of new index */
30     int32_t *CritMax,   /* (i/o) Maximum Criteria (so far) */
31     int16_t *shTotMax,   /* (i/o) Shifts of maximum criteria */
32     size_t *bestIndex,   /* (i/o) Index that corresponds to
33                                                    maximum criteria */
34     int16_t *bestGain)   /* (i/o) Gain in Q14 that corresponds
35                                                    to maximum criteria */
36 {
37   int16_t shOld, shNew, tmp16;
38   int16_t scaleTmp;
39   int32_t gainW32;
40 
41   /* Normalize the new and old Criteria to the same domain */
42   if (CritNewSh>(*shTotMax)) {
43     shOld=WEBRTC_SPL_MIN(31,CritNewSh-(*shTotMax));
44     shNew=0;
45   } else {
46     shOld=0;
47     shNew=WEBRTC_SPL_MIN(31,(*shTotMax)-CritNewSh);
48   }
49 
50   /* Compare the two criterias. If the new one is better,
51      calculate the gain and store this index as the new best one
52   */
53 
54   if ((CritNew >> shNew) > (*CritMax >> shOld)) {
55 
56     tmp16 = (int16_t)WebRtcSpl_NormW32(cDotNew);
57     tmp16 = 16 - tmp16;
58 
59     /* Calculate the gain in Q14
60        Compensate for inverseEnergyshift in Q29 and that the energy
61        value was stored in a int16_t (shifted down 16 steps)
62        => 29-14+16 = 31 */
63 
64     scaleTmp = -energyShiftNew-tmp16+31;
65     scaleTmp = WEBRTC_SPL_MIN(31, scaleTmp);
66 
67     gainW32 = ((int16_t)WEBRTC_SPL_SHIFT_W32(cDotNew, -tmp16) * invEnergyNew) >>
68         scaleTmp;
69 
70     /* Check if criteria satisfies Gain criteria (max 1.3)
71        if it is larger set the gain to 1.3
72        (slightly different from FLP version)
73     */
74     if (gainW32>21299) {
75       *bestGain=21299;
76     } else if (gainW32<-21299) {
77       *bestGain=-21299;
78     } else {
79       *bestGain=(int16_t)gainW32;
80     }
81 
82     *CritMax=CritNew;
83     *shTotMax=CritNewSh;
84     *bestIndex = IndexNew;
85   }
86 
87   return;
88 }
89