Initialize Tizen 2.3
[external/opencore-amr.git] / opencore / codecs_v2 / audio / gsm_amr / amr_wb / dec / src / preemph_amrwb_dec.cpp
1 /* ------------------------------------------------------------------
2  * Copyright (C) 1998-2009 PacketVideo
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
13  * express or implied.
14  * See the License for the specific language governing permissions
15  * and limitations under the License.
16  * -------------------------------------------------------------------
17  */
18 /****************************************************************************************
19 Portions of this file are derived from the following 3GPP standard:
20
21     3GPP TS 26.173
22     ANSI-C code for the Adaptive Multi-Rate - Wideband (AMR-WB) speech codec
23     Available from http://www.3gpp.org
24
25 (C) 2007, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TTA, TTC)
26 Permission to distribute, modify and use this file under the standard license
27 terms listed above has been obtained from the copyright holder.
28 ****************************************************************************************/
29 /*
30 ------------------------------------------------------------------------------
31
32
33
34  Filename: preemph_amrwb_dec.cpp
35
36 ------------------------------------------------------------------------------
37  INPUT AND OUTPUT DEFINITIONS
38
39      int16 x[],         (i/o)   : input signal overwritten by the output
40      int16 mu,          (i) Q15 : preemphasis coefficient
41      int16 lg           (i)     : lenght of filtering
42
43 ------------------------------------------------------------------------------
44  FUNCTION DESCRIPTION
45
46     Preemphasis: filtering through 1 - g z^-1
47
48 ------------------------------------------------------------------------------
49  REQUIREMENTS
50
51
52 ------------------------------------------------------------------------------
53  REFERENCES
54
55 ------------------------------------------------------------------------------
56  PSEUDO-CODE
57
58 ------------------------------------------------------------------------------
59 */
60
61 /*----------------------------------------------------------------------------
62 ; INCLUDES
63 ----------------------------------------------------------------------------*/
64
65 #include "pv_amr_wb_type_defs.h"
66 #include "pvamrwbdecoder_basic_op.h"
67 #include "pvamrwbdecoder_acelp.h"
68
69 /*----------------------------------------------------------------------------
70 ; MACROS
71 ; Define module specific macros here
72 ----------------------------------------------------------------------------*/
73
74
75 /*----------------------------------------------------------------------------
76 ; DEFINES
77 ; Include all pre-processor statements here. Include conditional
78 ; compile variables also.
79 ----------------------------------------------------------------------------*/
80
81 /*----------------------------------------------------------------------------
82 ; LOCAL FUNCTION DEFINITIONS
83 ; Function Prototype declaration
84 ----------------------------------------------------------------------------*/
85
86 /*----------------------------------------------------------------------------
87 ; LOCAL STORE/BUFFER/POINTER DEFINITIONS
88 ; Variable declaration - defined here and used outside this module
89 ----------------------------------------------------------------------------*/
90
91 /*----------------------------------------------------------------------------
92 ; EXTERNAL FUNCTION REFERENCES
93 ; Declare functions defined elsewhere and referenced in this module
94 ----------------------------------------------------------------------------*/
95
96 /*----------------------------------------------------------------------------
97 ; EXTERNAL GLOBAL STORE/BUFFER/POINTER REFERENCES
98 ; Declare variables used in this module but defined elsewhere
99 ----------------------------------------------------------------------------*/
100
101 /*----------------------------------------------------------------------------
102 ; FUNCTION CODE
103 ----------------------------------------------------------------------------*/
104
105
106 void preemph_amrwb_dec(
107     int16 x[],         /* (i/o)   : input signal overwritten by the output */
108     int16 mu,          /* (i) Q15 : preemphasis coefficient                */
109     int16 lg           /* (i)     : lenght of filtering                    */
110 )
111 {
112     int16 i;
113     int32 L_tmp;
114
115     for (i = lg - 1; i != 0; i--)
116     {
117         L_tmp = msu_16by16_from_int32((int32)x[i] << 16, x[i - 1], mu);
118         x[i] = amr_wb_round(L_tmp);
119     }
120
121 }
122