Git init
[external/opencore-amr.git] / opencore / codecs_v2 / audio / gsm_amr / amr_nb / dec / src / b_cn_cod.h
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.073
22     ANSI-C code for the Adaptive Multi-Rate (AMR) speech codec
23     Available from http://www.3gpp.org
24
25 (C) 2004, 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: b_cn_cod.h
35
36 ------------------------------------------------------------------------------
37  INCLUDE DESCRIPTION
38
39  This file contains all the constant definitions and prototype definitions
40  needed by the comfort noise(CN) generator functions
41
42 ------------------------------------------------------------------------------
43 */
44
45 #ifndef B_CN_COD_H
46 #define B_CN_COD_H
47
48 /*----------------------------------------------------------------------------
49 ; INCLUDES
50 ----------------------------------------------------------------------------*/
51 #include    "basicop_malloc.h"
52
53 /*--------------------------------------------------------------------------*/
54 #ifdef __cplusplus
55 extern "C"
56 {
57 #endif
58
59     /*----------------------------------------------------------------------------
60     ; MACROS
61     ; Define module specific macros here
62     ----------------------------------------------------------------------------*/
63
64     /*----------------------------------------------------------------------------
65     ; DEFINES
66     ; Include all pre-processor statements here.
67     ----------------------------------------------------------------------------*/
68
69     /*----------------------------------------------------------------------------
70     ; EXTERNAL VARIABLES REFERENCES
71     ; Declare variables used in this module but defined elsewhere
72     ----------------------------------------------------------------------------*/
73
74     /*----------------------------------------------------------------------------
75     ; SIMPLE TYPEDEF'S
76     ----------------------------------------------------------------------------*/
77
78     /*----------------------------------------------------------------------------
79     ; ENUMERATED TYPEDEF'S
80     ----------------------------------------------------------------------------*/
81
82     /*----------------------------------------------------------------------------
83     ; STRUCTURES TYPEDEF'S
84     ----------------------------------------------------------------------------*/
85
86     /*----------------------------------------------------------------------------
87     ; GLOBAL FUNCTION DEFINITIONS
88     ; Function Prototype declaration
89     ----------------------------------------------------------------------------*/
90
91     /*----------------------------------------------------------------------------
92
93     ; FUNCTION NAME: pseudonoise
94     ;
95     ; PURPOSE: Generate a random integer value to use in comfort noise
96     ;          generation. The algorithm uses polynomial x^31 + x^3 + 1
97     ;          (length of PN sequence is 2^31 - 1).
98     ;
99     ----------------------------------------------------------------------------*/
100
101     Word16 pseudonoise(
102         Word32 *pShift_reg,     /* i/o : Old CN generator shift register state */
103         Word16 no_bits          /* i   : Number of bits                        */
104     );
105
106     /*----------------------------------------------------------------------------
107
108     ; FUNCTION NAME: build_CN_code
109     ;
110     ; PURPOSE: Compute the comfort noise fixed codebook excitation. The
111     ;          gains of the pulses are always +/-1.
112     ;
113     ----------------------------------------------------------------------------*/
114
115     void build_CN_code(
116         Word32 *pSeed,          /* i/o : Old CN generator shift register state  */
117         Word16 cod[],           /* o   : Generated CN fixed codebook vector     */
118         Flag   *pOverflow       /* i/o : Overflow flag                          */
119     );
120
121     /*----------------------------------------------------------------------------
122
123     ; FUNCTION NAME: build_CN_param
124     ;
125     ; PURPOSE: Randomize the speech parameters. So that they
126     ;          do not produce tonal artifacts if used by ECU.
127     ;
128     ----------------------------------------------------------------------------*/
129
130     void build_CN_param(
131         Word16 *pSeed,          /* i/o : Old CN generator shift register state  */
132         const Word16 n_param,               /* i  : number of params            */
133         const Word16 param_size_table[],    /* i : size of params               */
134         Word16 parm[],                  /* o : CN Generated params              */
135         const Word16* window_200_40_ptr, /* i : ptr to read-only table          */
136         Flag  *pOverflow                /* i/o : Overflow Flag                  */
137     );
138
139     /*----------------------------------------------------------------------------
140     ; END
141     ----------------------------------------------------------------------------*/
142 #ifdef __cplusplus
143 }
144 #endif
145
146 #endif /* _B_CN_COD_H_ */
147