1b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber/* ------------------------------------------------------------------
2b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * Copyright (C) 1998-2009 PacketVideo
3b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber *
4b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * Licensed under the Apache License, Version 2.0 (the "License");
5b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * you may not use this file except in compliance with the License.
6b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * You may obtain a copy of the License at
7b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber *
8b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber *      http://www.apache.org/licenses/LICENSE-2.0
9b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber *
10b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * Unless required by applicable law or agreed to in writing, software
11b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * distributed under the License is distributed on an "AS IS" BASIS,
12b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
13b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * express or implied.
14b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * See the License for the specific language governing permissions
15b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * and limitations under the License.
16b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber * -------------------------------------------------------------------
17b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber */
18b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber/****************************************************************************************
19b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas HuberPortions of this file are derived from the following 3GPP standard:
20b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
21b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    3GPP TS 26.073
22b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ANSI-C code for the Adaptive Multi-Rate (AMR) speech codec
23b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    Available from http://www.3gpp.org
24b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
25b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber(C) 2004, 3GPP Organizational Partners (ARIB, ATIS, CCSA, ETSI, TTA, TTC)
26b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas HuberPermission to distribute, modify and use this file under the standard license
27b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huberterms listed above has been obtained from the copyright holder.
28b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber****************************************************************************************/
29b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber/*
30b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber------------------------------------------------------------------------------
31b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
32b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
33b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
34b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber Filename: /audio/gsm_amr/c/src/include/cod_amr.h
35b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
36b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     Date: 02/07/2002
37b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
38b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber------------------------------------------------------------------------------
39b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber REVISION HISTORY
40b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
41b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber Description: Added overflow flag as an element to the cod_amrState data
42b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber              structure. Corrected the function prototype declaration for
43b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber              cod_amr().
44b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
45b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber Description:  Replaced "int" and/or "char" with OSCL defined types.
46b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
47b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber Description: Moved _cplusplus #ifdef after Include section.
48b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
49b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber Description:
50b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
51b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber------------------------------------------------------------------------------
52b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber INCLUDE DESCRIPTION
53b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
54b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber       File             : cod_amr.h
55b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber       Purpose          : Main encoder routine operating on a frame basis.
56b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
57b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber------------------------------------------------------------------------------
58b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber*/
59b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
60b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#ifndef cod_amr_h
61b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#define cod_amr_h "$Id $"
62b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
63b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber/*----------------------------------------------------------------------------
64b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber; INCLUDES
65b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber----------------------------------------------------------------------------*/
66b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "typedef.h"
67b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "cnst.h"
68b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "mode.h"
69b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "lpc.h"
70b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "lsp.h"
71b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "cl_ltp.h"
72b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "gain_q.h"
73b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "p_ol_wgh.h"
74b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "ton_stab.h"
75b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "vad.h"
76b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#include "dtx_enc.h"
77b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
78b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber/*--------------------------------------------------------------------------*/
79b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#ifdef __cplusplus
80b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huberextern "C"
81b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber{
82b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#endif
83b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
84b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
85b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; MACROS
86b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; [Define module specific macros here]
87b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
88b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
89b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
90b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; DEFINES
91b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; [Include all pre-processor statements here.]
92b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
93b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
94b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
95b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
96b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; EXTERNAL VARIABLES REFERENCES
97b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; [Declare variables used in this module but defined elsewhere]
98b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
99b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
100b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
101b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; SIMPLE TYPEDEF'S
102b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
103b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
104b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
105b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; ENUMERATED TYPEDEF'S
106b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
107b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
108b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
109b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; STRUCTURES TYPEDEF'S
110b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
111b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*-----------------------------------------------------------*
112b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *    Coder constant parameters (defined in "cnst.h")        *
113b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *-----------------------------------------------------------*
114b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_WINDOW    : LPC analysis window size.                 *
115b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_NEXT      : Samples of next frame needed for autocor. *
116b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_FRAME     : Frame size.                               *
117b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_FRAME_BY2 : Half the frame size.                      *
118b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_SUBFR     : Sub-frame size.                           *
119b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   M           : LPC order.                                *
120b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   MP1         : LPC order+1                               *
121b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_TOTAL7k4  : Total size of speech buffer.              *
122b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   PIT_MIN7k4  : Minimum pitch lag.                        *
123b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   PIT_MAX     : Maximum pitch lag.                        *
124b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   L_INTERPOL  : Length of filter for interpolation        *
125b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *-----------------------------------------------------------*/
126b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    typedef struct
127b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    {
128b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Speech vector */
129b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 old_speech[L_TOTAL];
130b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *speech, *p_window, *p_window_12k2;
131b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *new_speech;             /* Global variable */
132b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
133b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Weight speech vector */
134b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 old_wsp[L_FRAME + PIT_MAX];
135b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *wsp;
136b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
137b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* OL LTP states */
138b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 old_lags[5];
139b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 ol_gain_flg[2];
140b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
141b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Excitation vector */
142b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 old_exc[L_FRAME + PIT_MAX + L_INTERPOL];
143b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *exc;
144b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
145b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Zero vector */
146b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 ai_zero[L_SUBFR + MP1];
147b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *zero;
148b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
149b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Impulse response vector */
150b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 *h1;
151b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 hvec[L_SUBFR * 2];
152b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
153b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Substates */
154b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        lpcState   *lpcSt;
155b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        lspState   *lspSt;
156b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        clLtpState *clLtpSt;
157b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        gainQuantState  *gainQuantSt;
158b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        pitchOLWghtState *pitchOLWghtSt;
159b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        tonStabState *tonStabSt;
160b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        vadState *vadSt;
161b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Flag dtx;
162b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        dtx_encState *dtx_encSt;
163b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
164b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Filter's memory */
165b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 mem_syn[M], mem_w0[M], mem_w[M];
166b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 mem_err[M + L_SUBFR], *error;
167b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
168b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Word16 sharp;
169b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
170b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        /* Overflow flag */
171b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber        Flag   overflow;
172b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
173b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    } cod_amrState;
174b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
175b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
176b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*----------------------------------------------------------------------------
177b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; GLOBAL FUNCTION DEFINITIONS
178b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ; [List function prototypes here]
179b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    ----------------------------------------------------------------------------*/
180b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*
181b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
182b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
183b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Function    : cod_amr_init
184b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Purpose     : Allocates memory and initializes state variables
185b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Description : Stores pointer to filter status struct in *st. This
186b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *                pointer has to be passed to cod_amr in each call.
187b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *                 - initilize pointers to speech buffer
188b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *                 - initialize static  pointers
189b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *                 - set static vectors to zero
190b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Returns     : 0 on success
191b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
192b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
193b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    */
194b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    Word16 cod_amr_init(cod_amrState **st, Flag dtx);
195b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
196b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*
197b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
198b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
199b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Function    : cod_amr_reset
200b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Purpose     : Resets state memory
201b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Returns     : 0 on success
202b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
203b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
204b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    */
205b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    Word16 cod_amr_reset(cod_amrState *st);
206b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
207b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /*
208b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
209b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
210b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Function    : cod_amr_exit
211b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Purpose     : The memory used for state memory is freed
212b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *  Description : Stores NULL in *st
213b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    *
214b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    **************************************************************************
215b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    */
216b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    void cod_amr_exit(cod_amrState **st);
217b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
218b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /***************************************************************************
219b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   FUNCTION:   cod_amr_first
220b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
221b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   PURPOSE:  Copes with look-ahead.
222b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
223b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   INPUTS:
224b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       No input argument are passed to this function. However, before
225b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       calling this function, 40 new speech data should be copied to the
226b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       vector new_speech[]. This is a global pointer which is declared in
227b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       this file (it points to the end of speech buffer minus 200).
228b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
229b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     ***************************************************************************/
230b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
231b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    Word16 cod_amr_first(cod_amrState *st,     /* i/o : State struct            */
232b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                         Word16 new_speech[]   /* i   : speech input (L_FRAME)  */
233b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                        );
234b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
235b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    /***************************************************************************
236b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   FUNCTION:   cod_amr
237b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
238b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   PURPOSE:  Main encoder routine.
239b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
240b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   DESCRIPTION: This function is called every 20 ms speech frame,
241b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       operating on the newly read 160 speech samples. It performs the
242b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       principle encoding functions to produce the set of encoded parameters
243b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       which include the LSP, adaptive codebook, and fixed codebook
244b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       quantization indices (addresses and gains).
245b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
246b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   INPUTS:
247b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       No input argument are passed to this function. However, before
248b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       calling this function, 160 new speech data should be copied to the
249b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       vector new_speech[]. This is a global pointer which is declared in
250b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       this file (it points to the end of speech buffer minus 160).
251b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
252b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *   OUTPUTS:
253b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
254b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       ana[]:     vector of analysis parameters.
255b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *       synth[]:   Local synthesis speech (for debugging purposes)
256b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     *
257b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber     ***************************************************************************/
258b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
259b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber    Word16 cod_amr(cod_amrState *st,         /* i/o : State struct                 */
260b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                   enum Mode mode,           /* i   : AMR mode                     */
261b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                   Word16 new_speech[],      /* i   : speech input (L_FRAME)       */
262b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                   Word16 ana[],             /* o   : Analysis parameters          */
263b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                   enum Mode *usedMode,      /* o   : used mode                    */
264b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                   Word16 synth[]            /* o   : Local synthesis              */
265b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber                  );
266b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
267b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
268b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#ifdef __cplusplus
269b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber}
270b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#endif
271b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
272b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber#endif  /* _cod_amr_h_ */
273b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
274b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
275b841f14f8e51f2365945281fbfa54ef6a1b1b5a6Andreas Huber
276