1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * QCELP decoder
3cabdff1aSopenharmony_ci * Copyright (c) 2007 Reynaldo H. Verdejo Pinochet
4cabdff1aSopenharmony_ci *
5cabdff1aSopenharmony_ci * This file is part of FFmpeg.
6cabdff1aSopenharmony_ci *
7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
11cabdff1aSopenharmony_ci *
12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15cabdff1aSopenharmony_ci * Lesser General Public License for more details.
16cabdff1aSopenharmony_ci *
17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20cabdff1aSopenharmony_ci */
21cabdff1aSopenharmony_ci
22cabdff1aSopenharmony_ci#ifndef AVCODEC_QCELPDATA_H
23cabdff1aSopenharmony_ci#define AVCODEC_QCELPDATA_H
24cabdff1aSopenharmony_ci
25cabdff1aSopenharmony_ci/**
26cabdff1aSopenharmony_ci * @file
27cabdff1aSopenharmony_ci * Data tables for the QCELP decoder
28cabdff1aSopenharmony_ci * @author Reynaldo H. Verdejo Pinochet
29cabdff1aSopenharmony_ci * @remark FFmpeg merging spearheaded by Kenan Gillet
30cabdff1aSopenharmony_ci * @remark Development mentored by Benjamin Larson
31cabdff1aSopenharmony_ci */
32cabdff1aSopenharmony_ci
33cabdff1aSopenharmony_ci#include <stddef.h>
34cabdff1aSopenharmony_ci#include <stdint.h>
35cabdff1aSopenharmony_ci#include "libavutil/common.h"
36cabdff1aSopenharmony_ci
37cabdff1aSopenharmony_ci/**
38cabdff1aSopenharmony_ci * QCELP unpacked data frame
39cabdff1aSopenharmony_ci */
40cabdff1aSopenharmony_citypedef struct QCELPFrame {
41cabdff1aSopenharmony_ci/// @name QCELP excitation codebook parameters
42cabdff1aSopenharmony_ci/// @{
43cabdff1aSopenharmony_ci    uint8_t cbsign[16]; ///< sign of the codebook gain for each codebook subframe
44cabdff1aSopenharmony_ci    uint8_t cbgain[16]; ///< unsigned codebook gain for each codebook subframe
45cabdff1aSopenharmony_ci    uint8_t cindex[16]; ///< codebook index for each codebook subframe
46cabdff1aSopenharmony_ci/// @}
47cabdff1aSopenharmony_ci
48cabdff1aSopenharmony_ci/// @name QCELP pitch prediction parameters
49cabdff1aSopenharmony_ci/// @{
50cabdff1aSopenharmony_ci    uint8_t plag[4];    ///< pitch lag for each pitch subframe
51cabdff1aSopenharmony_ci    uint8_t pfrac[4];   ///< fractional pitch lag for each pitch subframe
52cabdff1aSopenharmony_ci    uint8_t pgain[4];   ///< pitch gain for each pitch subframe
53cabdff1aSopenharmony_ci/// @}
54cabdff1aSopenharmony_ci
55cabdff1aSopenharmony_ci    /**
56cabdff1aSopenharmony_ci     * line spectral pair frequencies (LSP) for RATE_OCTAVE,
57cabdff1aSopenharmony_ci     * line spectral pair frequencies grouped into five vectors
58cabdff1aSopenharmony_ci     * of dimension two (LSPV) for other rates
59cabdff1aSopenharmony_ci     */
60cabdff1aSopenharmony_ci    uint8_t lspv[10];
61cabdff1aSopenharmony_ci
62cabdff1aSopenharmony_ci    /**
63cabdff1aSopenharmony_ci     * reserved bits only present in bitrate 1, 1/4 and 1/8 packets
64cabdff1aSopenharmony_ci     */
65cabdff1aSopenharmony_ci    uint8_t reserved;
66cabdff1aSopenharmony_ci} QCELPFrame;
67cabdff1aSopenharmony_ci
68cabdff1aSopenharmony_ci/**
69cabdff1aSopenharmony_ci * Pre-calculated table for hammsinc function.
70cabdff1aSopenharmony_ci * Only half of the table is needed because of symmetry.
71cabdff1aSopenharmony_ci *
72cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.5.2-2/3
73cabdff1aSopenharmony_ci */
74cabdff1aSopenharmony_cistatic const float qcelp_hammsinc_table[4] = { -0.006822,  0.041249, -0.143459,  0.588863};
75cabdff1aSopenharmony_ci
76cabdff1aSopenharmony_citypedef struct QCELPBitmap {
77cabdff1aSopenharmony_ci    uint8_t index;  /**< index into the QCELPContext structure */
78cabdff1aSopenharmony_ci    uint8_t bitpos; /**< position of the lowest bit in the value's byte */
79cabdff1aSopenharmony_ci    uint8_t bitlen; /**< number of bits to read */
80cabdff1aSopenharmony_ci} QCELPBitmap;
81cabdff1aSopenharmony_ci
82cabdff1aSopenharmony_ci#define QCELP_OF(variable, bit, len) {offsetof(QCELPFrame, variable), bit, len}
83cabdff1aSopenharmony_ci
84cabdff1aSopenharmony_ci/**
85cabdff1aSopenharmony_ci * Bitmap unpacking tables for RATE_FULL
86cabdff1aSopenharmony_ci *
87cabdff1aSopenharmony_ci * TIA/EIA/IS-733 Table 2.4.7.1-1
88cabdff1aSopenharmony_ci */
89cabdff1aSopenharmony_cistatic const QCELPBitmap qcelp_rate_full_bitmap[] = {
90cabdff1aSopenharmony_ci                                // start on bit
91cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 2], 0, 3), // 265
92cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 1], 0, 7), // 262
93cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 0], 0, 6), // 255
94cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 4], 0, 6), // 249
95cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 3], 0, 6), // 243
96cabdff1aSopenharmony_ci    QCELP_OF(lspv  [ 2], 3, 4), // 237
97cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 0], 0, 1), // 233
98cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 0], 0, 4), // 232
99cabdff1aSopenharmony_ci    QCELP_OF(pfrac [ 0], 0, 1), // 228
100cabdff1aSopenharmony_ci    QCELP_OF(plag  [ 0], 0, 7), // 227
101cabdff1aSopenharmony_ci    QCELP_OF(pgain [ 0], 0, 3), // 220
102cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 1], 0, 4), // 217
103cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 1], 0, 1), // 213
104cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 1], 0, 4), // 212
105cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 0], 0, 7), // 208
106cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 3], 0, 1), // 201
107cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 2], 0, 7), // 200
108cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 2], 0, 1), // 193
109cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 2], 0, 4), // 192
110cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 1], 4, 3), // 188
111cabdff1aSopenharmony_ci    QCELP_OF(plag  [ 1], 0, 3), // 185
112cabdff1aSopenharmony_ci    QCELP_OF(pgain [ 1], 0, 3), // 182
113cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 3], 0, 7), // 179
114cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 3], 0, 1), // 172
115cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 3], 1, 2), // 171
116cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 4], 0, 6), // 169
117cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 4], 0, 1), // 163
118cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 4], 0, 4), // 162
119cabdff1aSopenharmony_ci    QCELP_OF(pfrac [ 1], 0, 1), // 158
120cabdff1aSopenharmony_ci    QCELP_OF(plag  [ 1], 3, 4), // 157
121cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 6], 0, 3), // 153
122cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 5], 0, 7), // 150
123cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 5], 0, 1), // 143
124cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 5], 0, 4), // 142
125cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 4], 6, 1), // 138
126cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 7], 0, 3), // 137
127cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 7], 0, 1), // 134
128cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 7], 0, 3), // 133
129cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 6], 0, 7), // 130
130cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 6], 0, 1), // 123
131cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 6], 3, 1), // 122
132cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 8], 0, 1), // 121
133cabdff1aSopenharmony_ci    QCELP_OF(pfrac [ 2], 0, 1), // 120
134cabdff1aSopenharmony_ci    QCELP_OF(plag  [ 2], 0, 7), // 119
135cabdff1aSopenharmony_ci    QCELP_OF(pgain [ 2], 0, 3), // 112
136cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 7], 3, 4), // 109
137cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 9], 0, 1), // 105
138cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 9], 0, 4), // 104
139cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 8], 0, 7), // 100
140cabdff1aSopenharmony_ci    QCELP_OF(cbsign[ 8], 0, 1), //  93
141cabdff1aSopenharmony_ci    QCELP_OF(cbgain[ 8], 1, 3), //  92
142cabdff1aSopenharmony_ci    QCELP_OF(cindex[10], 0, 4), //  89
143cabdff1aSopenharmony_ci    QCELP_OF(cbsign[10], 0, 1), //  85
144cabdff1aSopenharmony_ci    QCELP_OF(cbgain[10], 0, 4), //  84
145cabdff1aSopenharmony_ci    QCELP_OF(cindex[ 9], 0, 7), //  80
146cabdff1aSopenharmony_ci    QCELP_OF(pgain [ 3], 0, 2), //  73
147cabdff1aSopenharmony_ci    QCELP_OF(cindex[11], 0, 7), //  71
148cabdff1aSopenharmony_ci    QCELP_OF(cbsign[11], 0, 1), //  64
149cabdff1aSopenharmony_ci    QCELP_OF(cbgain[11], 0, 3), //  63
150cabdff1aSopenharmony_ci    QCELP_OF(cindex[10], 4, 3), //  60
151cabdff1aSopenharmony_ci    QCELP_OF(cindex[12], 0, 2), //  57
152cabdff1aSopenharmony_ci    QCELP_OF(cbsign[12], 0, 1), //  55
153cabdff1aSopenharmony_ci    QCELP_OF(cbgain[12], 0, 4), //  54
154cabdff1aSopenharmony_ci    QCELP_OF(pfrac [ 3], 0, 1), //  50
155cabdff1aSopenharmony_ci    QCELP_OF(plag  [ 3], 0, 7), //  49
156cabdff1aSopenharmony_ci    QCELP_OF(pgain [ 3], 2, 1), //  42
157cabdff1aSopenharmony_ci    QCELP_OF(cindex[13], 0, 6), //  41
158cabdff1aSopenharmony_ci    QCELP_OF(cbsign[13], 0, 1), //  35
159cabdff1aSopenharmony_ci    QCELP_OF(cbgain[13], 0, 4), //  34
160cabdff1aSopenharmony_ci    QCELP_OF(cindex[12], 2, 5), //  30
161cabdff1aSopenharmony_ci    QCELP_OF(cbgain[15], 0, 3), //  25
162cabdff1aSopenharmony_ci    QCELP_OF(cindex[14], 0, 7), //  22
163cabdff1aSopenharmony_ci    QCELP_OF(cbsign[14], 0, 1), //  15
164cabdff1aSopenharmony_ci    QCELP_OF(cbgain[14], 0, 4), //  14
165cabdff1aSopenharmony_ci    QCELP_OF(cindex[13], 6, 1), //  10
166cabdff1aSopenharmony_ci    QCELP_OF(reserved,   0, 2), //   9
167cabdff1aSopenharmony_ci    QCELP_OF(cindex[15], 0, 7), //   7
168cabdff1aSopenharmony_ci    QCELP_OF(cbsign[15], 0, 1)  //   0
169cabdff1aSopenharmony_ci};
170cabdff1aSopenharmony_ci
171cabdff1aSopenharmony_ci/**
172cabdff1aSopenharmony_ci * Bitmap unpacking tables for RATE_HALF
173cabdff1aSopenharmony_ci *
174cabdff1aSopenharmony_ci * TIA/EIA/IS-733 Table 2.4.7.2-1
175cabdff1aSopenharmony_ci */
176cabdff1aSopenharmony_cistatic const QCELPBitmap qcelp_rate_half_bitmap[] = {
177cabdff1aSopenharmony_ci                               // start on bit
178cabdff1aSopenharmony_ci    QCELP_OF(lspv  [2], 0, 3), // 123
179cabdff1aSopenharmony_ci    QCELP_OF(lspv  [1], 0, 7), // 120
180cabdff1aSopenharmony_ci    QCELP_OF(lspv  [0], 0, 6), // 113
181cabdff1aSopenharmony_ci    QCELP_OF(lspv  [4], 0, 6), // 107
182cabdff1aSopenharmony_ci    QCELP_OF(lspv  [3], 0, 6), // 101
183cabdff1aSopenharmony_ci    QCELP_OF(lspv  [2], 3, 4), //  95
184cabdff1aSopenharmony_ci    QCELP_OF(cbsign[0], 0, 1), //  91
185cabdff1aSopenharmony_ci    QCELP_OF(cbgain[0], 0, 4), //  90
186cabdff1aSopenharmony_ci    QCELP_OF(pfrac [0], 0, 1), //  86
187cabdff1aSopenharmony_ci    QCELP_OF(plag  [0], 0, 7), //  85
188cabdff1aSopenharmony_ci    QCELP_OF(pgain [0], 0, 3), //  78
189cabdff1aSopenharmony_ci    QCELP_OF(plag  [1], 0, 6), //  75
190cabdff1aSopenharmony_ci    QCELP_OF(pgain [1], 0, 3), //  69
191cabdff1aSopenharmony_ci    QCELP_OF(cindex[0], 0, 7), //  66
192cabdff1aSopenharmony_ci    QCELP_OF(pgain [2], 0, 2), //  59
193cabdff1aSopenharmony_ci    QCELP_OF(cindex[1], 0, 7), //  57
194cabdff1aSopenharmony_ci    QCELP_OF(cbsign[1], 0, 1), //  50
195cabdff1aSopenharmony_ci    QCELP_OF(cbgain[1], 0, 4), //  49
196cabdff1aSopenharmony_ci    QCELP_OF(pfrac [1], 0, 1), //  45
197cabdff1aSopenharmony_ci    QCELP_OF(plag  [1], 6, 1), //  44
198cabdff1aSopenharmony_ci    QCELP_OF(cindex[2], 0, 2), //  43
199cabdff1aSopenharmony_ci    QCELP_OF(cbsign[2], 0, 1), //  41
200cabdff1aSopenharmony_ci    QCELP_OF(cbgain[2], 0, 4), //  40
201cabdff1aSopenharmony_ci    QCELP_OF(pfrac [2], 0, 1), //  36
202cabdff1aSopenharmony_ci    QCELP_OF(plag  [2], 0, 7), //  35
203cabdff1aSopenharmony_ci    QCELP_OF(pgain [2], 2, 1), //  28
204cabdff1aSopenharmony_ci    QCELP_OF(pfrac [3], 0, 1), //  27
205cabdff1aSopenharmony_ci    QCELP_OF(plag  [3], 0, 7), //  26
206cabdff1aSopenharmony_ci    QCELP_OF(pgain [3], 0, 3), //  19
207cabdff1aSopenharmony_ci    QCELP_OF(cindex[2], 2, 5), //  16
208cabdff1aSopenharmony_ci    QCELP_OF(cindex[3], 0, 7), //  11
209cabdff1aSopenharmony_ci    QCELP_OF(cbsign[3], 0, 1), //   4
210cabdff1aSopenharmony_ci    QCELP_OF(cbgain[3], 0, 4)  //   3
211cabdff1aSopenharmony_ci};
212cabdff1aSopenharmony_ci
213cabdff1aSopenharmony_ci/**
214cabdff1aSopenharmony_ci * Bitmap unpacking tables for RATE_QUARTER
215cabdff1aSopenharmony_ci *
216cabdff1aSopenharmony_ci * TIA/EIA/IS-733 Table 2.4.7.3-1
217cabdff1aSopenharmony_ci */
218cabdff1aSopenharmony_cistatic const QCELPBitmap qcelp_rate_quarter_bitmap[] = {
219cabdff1aSopenharmony_ci                               // start on bit
220cabdff1aSopenharmony_ci    QCELP_OF(lspv  [2], 0, 3), // 53
221cabdff1aSopenharmony_ci    QCELP_OF(lspv  [1], 0, 7), // 50
222cabdff1aSopenharmony_ci    QCELP_OF(lspv  [0], 0, 6), // 43
223cabdff1aSopenharmony_ci    QCELP_OF(lspv  [4], 0, 6), // 37
224cabdff1aSopenharmony_ci    QCELP_OF(lspv  [3], 0, 6), // 31
225cabdff1aSopenharmony_ci    QCELP_OF(lspv  [2], 3, 4), // 25
226cabdff1aSopenharmony_ci    QCELP_OF(cbgain[3], 0, 4), // 21
227cabdff1aSopenharmony_ci    QCELP_OF(cbgain[2], 0, 4), // 17
228cabdff1aSopenharmony_ci    QCELP_OF(cbgain[1], 0, 4), // 13
229cabdff1aSopenharmony_ci    QCELP_OF(cbgain[0], 0, 4), //  9
230cabdff1aSopenharmony_ci    QCELP_OF(reserved,  0, 2), //  5
231cabdff1aSopenharmony_ci    QCELP_OF(cbgain[4], 0, 4)  //  3
232cabdff1aSopenharmony_ci};
233cabdff1aSopenharmony_ci
234cabdff1aSopenharmony_ci/**
235cabdff1aSopenharmony_ci * Bitmap unpacking tables for RATE_OCTAVE
236cabdff1aSopenharmony_ci *
237cabdff1aSopenharmony_ci * trick: CBSEED is written into QCELPContext.cbsign[15],
238cabdff1aSopenharmony_ci * which is not used for RATE_OCTAVE.
239cabdff1aSopenharmony_ci * CBSEED is only used to ensure the occurrence of random bit
240cabdff1aSopenharmony_ci * patterns in the 16 first bits that are used as the seed.
241cabdff1aSopenharmony_ci *
242cabdff1aSopenharmony_ci * TIA/EIA/IS-733 Table 2.4.7.4-1
243cabdff1aSopenharmony_ci */
244cabdff1aSopenharmony_cistatic const QCELPBitmap qcelp_rate_octave_bitmap[] = {
245cabdff1aSopenharmony_ci                                // start on bit
246cabdff1aSopenharmony_ci    QCELP_OF(cbsign[15], 3, 1), // 19
247cabdff1aSopenharmony_ci    QCELP_OF(lspv   [0], 0, 1), // 18
248cabdff1aSopenharmony_ci    QCELP_OF(lspv   [1], 0, 1), // 17
249cabdff1aSopenharmony_ci    QCELP_OF(lspv   [2], 0, 1), // 16
250cabdff1aSopenharmony_ci    QCELP_OF(cbsign[15], 2, 1), // 15
251cabdff1aSopenharmony_ci    QCELP_OF(lspv   [3], 0, 1), // 14
252cabdff1aSopenharmony_ci    QCELP_OF(lspv   [4], 0, 1), // 13
253cabdff1aSopenharmony_ci    QCELP_OF(lspv   [5], 0, 1), // 12
254cabdff1aSopenharmony_ci    QCELP_OF(cbsign[15], 1, 1), // 11
255cabdff1aSopenharmony_ci    QCELP_OF(lspv   [6], 0, 1), // 10
256cabdff1aSopenharmony_ci    QCELP_OF(lspv   [7], 0, 1), //  9
257cabdff1aSopenharmony_ci    QCELP_OF(lspv   [8], 0, 1), //  8
258cabdff1aSopenharmony_ci    QCELP_OF(cbsign[15], 0, 1), //  7
259cabdff1aSopenharmony_ci    QCELP_OF(lspv   [9], 0, 1), //  6
260cabdff1aSopenharmony_ci    QCELP_OF(cbgain [0], 0, 2), //  5
261cabdff1aSopenharmony_ci    QCELP_OF(reserved,   0, 4)  //  3
262cabdff1aSopenharmony_ci};
263cabdff1aSopenharmony_ci
264cabdff1aSopenharmony_ci/**
265cabdff1aSopenharmony_ci * Bitmapping data position for each packet type in
266cabdff1aSopenharmony_ci * the QCELPContext
267cabdff1aSopenharmony_ci */
268cabdff1aSopenharmony_cistatic const QCELPBitmap * const qcelp_unpacking_bitmaps_per_rate[5] = {
269cabdff1aSopenharmony_ci    NULL,                     ///< for SILENCE rate
270cabdff1aSopenharmony_ci    qcelp_rate_octave_bitmap,
271cabdff1aSopenharmony_ci    qcelp_rate_quarter_bitmap,
272cabdff1aSopenharmony_ci    qcelp_rate_half_bitmap,
273cabdff1aSopenharmony_ci    qcelp_rate_full_bitmap,
274cabdff1aSopenharmony_ci};
275cabdff1aSopenharmony_ci
276cabdff1aSopenharmony_cistatic const uint16_t qcelp_unpacking_bitmaps_lengths[5] = {
277cabdff1aSopenharmony_ci    0, ///< for SILENCE rate
278cabdff1aSopenharmony_ci    FF_ARRAY_ELEMS(qcelp_rate_octave_bitmap),
279cabdff1aSopenharmony_ci    FF_ARRAY_ELEMS(qcelp_rate_quarter_bitmap),
280cabdff1aSopenharmony_ci    FF_ARRAY_ELEMS(qcelp_rate_half_bitmap),
281cabdff1aSopenharmony_ci    FF_ARRAY_ELEMS(qcelp_rate_full_bitmap),
282cabdff1aSopenharmony_ci};
283cabdff1aSopenharmony_ci
284cabdff1aSopenharmony_citypedef uint16_t qcelp_vector[2];
285cabdff1aSopenharmony_ci
286cabdff1aSopenharmony_ci/**
287cabdff1aSopenharmony_ci * LSP vector quantization tables in x*10000 form
288cabdff1aSopenharmony_ci *
289cabdff1aSopenharmony_ci * TIA/EIA/IS-733 tables 2.4.3.2.6.3-1 through 2.4.3.2.6.3-5
290cabdff1aSopenharmony_ci */
291cabdff1aSopenharmony_ci
292cabdff1aSopenharmony_cistatic const qcelp_vector qcelp_lspvq1[64]= {
293cabdff1aSopenharmony_ci{ 327, 118},{ 919, 111},{ 427, 440},{1327, 185},
294cabdff1aSopenharmony_ci{ 469,  50},{1272,  91},{ 892,  59},{1771, 193},
295cabdff1aSopenharmony_ci{ 222, 158},{1100, 127},{ 827,  55},{ 978, 791},
296cabdff1aSopenharmony_ci{ 665,  47},{ 700,1401},{ 670, 859},{1913,1048},
297cabdff1aSopenharmony_ci{ 471, 215},{1046, 125},{ 645, 298},{1599, 160},
298cabdff1aSopenharmony_ci{ 593,  39},{1187, 462},{ 749, 341},{1520, 511},
299cabdff1aSopenharmony_ci{ 290, 792},{ 909, 362},{ 753,  81},{1111,1058},
300cabdff1aSopenharmony_ci{ 519, 253},{ 828, 839},{ 685, 541},{1421,1258},
301cabdff1aSopenharmony_ci{ 386, 130},{ 962, 119},{ 542, 387},{1431, 185},
302cabdff1aSopenharmony_ci{ 526,  51},{1175, 260},{ 831, 167},{1728, 510},
303cabdff1aSopenharmony_ci{ 273, 437},{1172, 113},{ 771, 144},{1122, 751},
304cabdff1aSopenharmony_ci{ 619, 119},{ 492,1276},{ 658, 695},{1882, 615},
305cabdff1aSopenharmony_ci{ 415, 200},{1018,  88},{ 681, 339},{1436, 325},
306cabdff1aSopenharmony_ci{ 555, 122},{1042, 485},{ 826, 345},{1374, 743},
307cabdff1aSopenharmony_ci{ 383,1018},{1005, 358},{ 704,  86},{1301, 586},
308cabdff1aSopenharmony_ci{ 597, 241},{ 832, 621},{ 555, 573},{1504, 839}};
309cabdff1aSopenharmony_ci
310cabdff1aSopenharmony_cistatic const qcelp_vector qcelp_lspvq2[128]= {
311cabdff1aSopenharmony_ci{ 255, 293},{ 904, 219},{ 151,1211},{1447, 498},
312cabdff1aSopenharmony_ci{ 470, 253},{1559, 177},{1547, 994},{2394, 242},
313cabdff1aSopenharmony_ci{  91, 813},{ 857, 590},{ 934,1326},{1889, 282},
314cabdff1aSopenharmony_ci{ 813, 472},{1057,1494},{ 450,3315},{2163,1895},
315cabdff1aSopenharmony_ci{ 538, 532},{1399, 218},{ 146,1552},{1755, 626},
316cabdff1aSopenharmony_ci{ 822, 202},{1299, 663},{ 706,1732},{2656, 401},
317cabdff1aSopenharmony_ci{ 418, 745},{ 762,1038},{ 583,1748},{1746,1285},
318cabdff1aSopenharmony_ci{ 527,1169},{1314, 830},{ 556,2116},{1073,2321},
319cabdff1aSopenharmony_ci{ 297, 570},{ 981, 403},{ 468,1103},{1740, 243},
320cabdff1aSopenharmony_ci{ 725, 179},{1255, 474},{1374,1362},{1922, 912},
321cabdff1aSopenharmony_ci{ 285, 947},{ 930, 700},{ 593,1372},{1909, 576},
322cabdff1aSopenharmony_ci{ 588, 916},{1110,1116},{ 224,2719},{1633,2220},
323cabdff1aSopenharmony_ci{ 402, 520},{1061, 448},{ 402,1352},{1499, 775},
324cabdff1aSopenharmony_ci{ 664, 589},{1081, 727},{ 801,2206},{2165,1157},
325cabdff1aSopenharmony_ci{ 566, 802},{ 911,1116},{ 306,1703},{1792, 836},
326cabdff1aSopenharmony_ci{ 655, 999},{1061,1038},{ 298,2089},{1110,1753},
327cabdff1aSopenharmony_ci{ 361, 311},{ 970, 239},{ 265,1231},{1495, 573},
328cabdff1aSopenharmony_ci{ 566, 262},{1569, 293},{1341,1144},{2271, 544},
329cabdff1aSopenharmony_ci{ 214, 877},{ 847, 719},{ 794,1384},{2067, 274},
330cabdff1aSopenharmony_ci{ 703, 688},{1099,1306},{ 391,2947},{2024,1670},
331cabdff1aSopenharmony_ci{ 471, 525},{1245, 290},{ 264,1557},{1568, 807},
332cabdff1aSopenharmony_ci{ 718, 399},{1193, 685},{ 883,1594},{2729, 764},
333cabdff1aSopenharmony_ci{ 500, 754},{ 809,1108},{ 541,1648},{1523,1385},
334cabdff1aSopenharmony_ci{ 614,1196},{1209, 847},{ 345,2242},{1442,1747},
335cabdff1aSopenharmony_ci{ 199, 560},{1092, 194},{ 349,1253},{1653, 507},
336cabdff1aSopenharmony_ci{ 625, 354},{1376, 431},{1187,1465},{2164, 872},
337cabdff1aSopenharmony_ci{ 360, 974},{1008, 698},{ 704,1346},{2114, 452},
338cabdff1aSopenharmony_ci{ 720, 816},{1240,1089},{ 439,2475},{1498,2040},
339cabdff1aSopenharmony_ci{ 336, 718},{1213, 187},{ 451,1450},{1368, 885},
340cabdff1aSopenharmony_ci{ 592, 578},{1131, 531},{ 861,1855},{1764,1500},
341cabdff1aSopenharmony_ci{ 444, 970},{ 935, 903},{ 424,1687},{1633,1102},
342cabdff1aSopenharmony_ci{ 793, 897},{1060, 897},{ 185,2011},{1205,1855}};
343cabdff1aSopenharmony_ci
344cabdff1aSopenharmony_cistatic const qcelp_vector qcelp_lspvq3[128]= {
345cabdff1aSopenharmony_ci{ 225, 283},{1296, 355},{ 543, 343},{2073, 274},
346cabdff1aSopenharmony_ci{ 204,1099},{1562, 523},{1388, 161},{2784, 274},
347cabdff1aSopenharmony_ci{ 112, 849},{1870, 175},{1189, 160},{1490,1088},
348cabdff1aSopenharmony_ci{ 969,1115},{ 659,3322},{1158,1073},{3183,1363},
349cabdff1aSopenharmony_ci{ 517, 223},{1740, 223},{ 704, 387},{2637, 234},
350cabdff1aSopenharmony_ci{ 692,1005},{1287,1610},{ 952, 532},{2393, 646},
351cabdff1aSopenharmony_ci{ 490, 552},{1619, 657},{ 845, 670},{1784,2280},
352cabdff1aSopenharmony_ci{ 191,1775},{ 272,2868},{ 942, 952},{2628,1479},
353cabdff1aSopenharmony_ci{ 278, 579},{1565, 218},{ 814, 180},{2379, 187},
354cabdff1aSopenharmony_ci{ 276,1444},{1199,1223},{1200, 349},{3009, 307},
355cabdff1aSopenharmony_ci{ 312, 844},{1898, 306},{ 863, 470},{1685,1241},
356cabdff1aSopenharmony_ci{ 513,1727},{ 711,2233},{1085, 864},{3398, 527},
357cabdff1aSopenharmony_ci{ 414, 440},{1356, 612},{ 964, 147},{2173, 738},
358cabdff1aSopenharmony_ci{ 465,1292},{ 877,1749},{1104, 689},{2105,1311},
359cabdff1aSopenharmony_ci{ 580, 864},{1895, 752},{ 652, 609},{1485,1699},
360cabdff1aSopenharmony_ci{ 514,1400},{ 386,2131},{ 933, 798},{2473, 986},
361cabdff1aSopenharmony_ci{ 334, 360},{1375, 398},{ 621, 276},{2183, 280},
362cabdff1aSopenharmony_ci{ 311,1114},{1382, 807},{1284, 175},{2605, 636},
363cabdff1aSopenharmony_ci{ 230, 816},{1739, 408},{1074, 176},{1619,1120},
364cabdff1aSopenharmony_ci{ 784,1371},{ 448,3050},{1189, 880},{3039,1165},
365cabdff1aSopenharmony_ci{ 424, 241},{1672, 186},{ 815, 333},{2432, 324},
366cabdff1aSopenharmony_ci{ 584,1029},{1137,1546},{1015, 585},{2198, 995},
367cabdff1aSopenharmony_ci{ 574, 581},{1746, 647},{ 733, 740},{1938,1737},
368cabdff1aSopenharmony_ci{ 347,1710},{ 373,2429},{ 787,1061},{2439,1438},
369cabdff1aSopenharmony_ci{ 185, 536},{1489, 178},{ 703, 216},{2178, 487},
370cabdff1aSopenharmony_ci{ 154,1421},{1414, 994},{1103, 352},{3072, 473},
371cabdff1aSopenharmony_ci{ 408, 819},{2055, 168},{ 998, 354},{1917,1140},
372cabdff1aSopenharmony_ci{ 665,1799},{ 993,2213},{1234, 631},{3003, 762},
373cabdff1aSopenharmony_ci{ 373, 620},{1518, 425},{ 913, 300},{1966, 836},
374cabdff1aSopenharmony_ci{ 402,1185},{ 948,1385},{1121, 555},{1802,1509},
375cabdff1aSopenharmony_ci{ 474, 886},{1888, 610},{ 739, 585},{1231,2379},
376cabdff1aSopenharmony_ci{ 661,1335},{ 205,2211},{ 823, 822},{2480,1179}};
377cabdff1aSopenharmony_ci
378cabdff1aSopenharmony_cistatic const qcelp_vector qcelp_lspvq4[64]= {
379cabdff1aSopenharmony_ci{ 348, 311},{ 812,1145},{ 552, 461},{1826, 263},
380cabdff1aSopenharmony_ci{ 601, 675},{1730, 172},{1523, 193},{2449, 277},
381cabdff1aSopenharmony_ci{ 334, 668},{ 805,1441},{1319, 207},{1684, 910},
382cabdff1aSopenharmony_ci{ 582,1318},{1403,1098},{ 979, 832},{2700,1359},
383cabdff1aSopenharmony_ci{ 624, 228},{1292, 979},{ 800, 195},{2226, 285},
384cabdff1aSopenharmony_ci{ 730, 862},{1537, 601},{1115, 509},{2720, 354},
385cabdff1aSopenharmony_ci{ 218,1167},{1212,1538},{1074, 247},{1674,1710},
386cabdff1aSopenharmony_ci{ 322,2142},{1263, 777},{ 981, 556},{2119,1710},
387cabdff1aSopenharmony_ci{ 193, 596},{1035, 957},{ 694, 397},{1997, 253},
388cabdff1aSopenharmony_ci{ 743, 603},{1584, 321},{1346, 346},{2221, 708},
389cabdff1aSopenharmony_ci{ 451, 732},{1040,1415},{1184, 230},{1853, 919},
390cabdff1aSopenharmony_ci{ 310,1661},{1625, 706},{ 856, 843},{2902, 702},
391cabdff1aSopenharmony_ci{ 467, 348},{1108,1048},{ 859, 306},{1964, 463},
392cabdff1aSopenharmony_ci{ 560,1013},{1425, 533},{1142, 634},{2391, 879},
393cabdff1aSopenharmony_ci{ 397,1084},{1345,1700},{ 976, 248},{1887,1189},
394cabdff1aSopenharmony_ci{ 644,2087},{1262, 603},{ 877, 550},{2203,1307}};
395cabdff1aSopenharmony_ci
396cabdff1aSopenharmony_cistatic const qcelp_vector qcelp_lspvq5[64]= {
397cabdff1aSopenharmony_ci{ 360, 222},{ 820,1097},{ 601, 319},{1656, 198},
398cabdff1aSopenharmony_ci{ 604, 513},{1552, 141},{1391, 155},{2474, 261},
399cabdff1aSopenharmony_ci{ 269, 785},{1463, 646},{1123, 191},{2015, 223},
400cabdff1aSopenharmony_ci{ 785, 844},{1202,1011},{ 980, 807},{3014, 793},
401cabdff1aSopenharmony_ci{ 570, 180},{1135,1382},{ 778, 256},{1901, 179},
402cabdff1aSopenharmony_ci{ 807, 622},{1461, 458},{1231, 178},{2028, 821},
403cabdff1aSopenharmony_ci{ 387, 927},{1496,1004},{ 888, 392},{2246, 341},
404cabdff1aSopenharmony_ci{ 295,1462},{1156, 694},{1022, 473},{2226,1364},
405cabdff1aSopenharmony_ci{ 210, 478},{1029,1020},{ 722, 181},{1730, 251},
406cabdff1aSopenharmony_ci{ 730, 488},{1465, 293},{1303, 326},{2595, 387},
407cabdff1aSopenharmony_ci{ 458, 584},{1569, 742},{1029, 173},{1910, 495},
408cabdff1aSopenharmony_ci{ 605,1159},{1268, 719},{ 973, 646},{2872, 428},
409cabdff1aSopenharmony_ci{ 443, 334},{ 835,1465},{ 912, 138},{1716, 442},
410cabdff1aSopenharmony_ci{ 620, 778},{1316, 450},{1186, 335},{1446,1665},
411cabdff1aSopenharmony_ci{ 486,1050},{1675,1019},{ 880, 278},{2214, 202},
412cabdff1aSopenharmony_ci{ 539,1564},{1142, 533},{ 984, 391},{2130,1089}};
413cabdff1aSopenharmony_ci
414cabdff1aSopenharmony_cistatic const qcelp_vector * const qcelp_lspvq[5] = {
415cabdff1aSopenharmony_ci    qcelp_lspvq1,
416cabdff1aSopenharmony_ci    qcelp_lspvq2,
417cabdff1aSopenharmony_ci    qcelp_lspvq3,
418cabdff1aSopenharmony_ci    qcelp_lspvq4,
419cabdff1aSopenharmony_ci    qcelp_lspvq5
420cabdff1aSopenharmony_ci};
421cabdff1aSopenharmony_ci
422cabdff1aSopenharmony_ci/**
423cabdff1aSopenharmony_ci * The final gain scalefactor before clipping into a usable output float
424cabdff1aSopenharmony_ci */
425cabdff1aSopenharmony_ci#define QCELP_SCALE 8192.
426cabdff1aSopenharmony_ci
427cabdff1aSopenharmony_ci/**
428cabdff1aSopenharmony_ci * Table for computing Ga (decoded linear codebook gain magnitude)
429cabdff1aSopenharmony_ci *
430cabdff1aSopenharmony_ci * @note The table could fit in int16_t in x*8 form, but it seems
431cabdff1aSopenharmony_ci *       to be slower on x86
432cabdff1aSopenharmony_ci *
433cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.6.2.1-3
434cabdff1aSopenharmony_ci */
435cabdff1aSopenharmony_ci
436cabdff1aSopenharmony_cistatic const float qcelp_g12ga[61] = {
437cabdff1aSopenharmony_ci    1.000/QCELP_SCALE,   1.125/QCELP_SCALE,   1.250/QCELP_SCALE,   1.375/QCELP_SCALE,
438cabdff1aSopenharmony_ci    1.625/QCELP_SCALE,   1.750/QCELP_SCALE,   2.000/QCELP_SCALE,   2.250/QCELP_SCALE,
439cabdff1aSopenharmony_ci    2.500/QCELP_SCALE,   2.875/QCELP_SCALE,   3.125/QCELP_SCALE,   3.500/QCELP_SCALE,
440cabdff1aSopenharmony_ci    4.000/QCELP_SCALE,   4.500/QCELP_SCALE,   5.000/QCELP_SCALE,   5.625/QCELP_SCALE,
441cabdff1aSopenharmony_ci    6.250/QCELP_SCALE,   7.125/QCELP_SCALE,   8.000/QCELP_SCALE,   8.875/QCELP_SCALE,
442cabdff1aSopenharmony_ci   10.000/QCELP_SCALE,  11.250/QCELP_SCALE,  12.625/QCELP_SCALE,  14.125/QCELP_SCALE,
443cabdff1aSopenharmony_ci   15.875/QCELP_SCALE,  17.750/QCELP_SCALE,  20.000/QCELP_SCALE,  22.375/QCELP_SCALE,
444cabdff1aSopenharmony_ci   25.125/QCELP_SCALE,  28.125/QCELP_SCALE,  31.625/QCELP_SCALE,  35.500/QCELP_SCALE,
445cabdff1aSopenharmony_ci   39.750/QCELP_SCALE,  44.625/QCELP_SCALE,  50.125/QCELP_SCALE,  56.250/QCELP_SCALE,
446cabdff1aSopenharmony_ci   63.125/QCELP_SCALE,  70.750/QCELP_SCALE,  79.375/QCELP_SCALE,  89.125/QCELP_SCALE,
447cabdff1aSopenharmony_ci  100.000/QCELP_SCALE, 112.250/QCELP_SCALE, 125.875/QCELP_SCALE, 141.250/QCELP_SCALE,
448cabdff1aSopenharmony_ci  158.500/QCELP_SCALE, 177.875/QCELP_SCALE, 199.500/QCELP_SCALE, 223.875/QCELP_SCALE,
449cabdff1aSopenharmony_ci  251.250/QCELP_SCALE, 281.875/QCELP_SCALE, 316.250/QCELP_SCALE, 354.875/QCELP_SCALE,
450cabdff1aSopenharmony_ci  398.125/QCELP_SCALE, 446.625/QCELP_SCALE, 501.125/QCELP_SCALE, 562.375/QCELP_SCALE,
451cabdff1aSopenharmony_ci  631.000/QCELP_SCALE, 708.000/QCELP_SCALE, 794.375/QCELP_SCALE, 891.250/QCELP_SCALE,
452cabdff1aSopenharmony_ci 1000.000/QCELP_SCALE};
453cabdff1aSopenharmony_ci
454cabdff1aSopenharmony_ci/**
455cabdff1aSopenharmony_ci * Circular codebook for rate 1 frames in x*100 form
456cabdff1aSopenharmony_ci *
457cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.6.1-2
458cabdff1aSopenharmony_ci */
459cabdff1aSopenharmony_cistatic const int16_t qcelp_rate_full_codebook[128] = {
460cabdff1aSopenharmony_ci     10,  -65,  -59,   12,  110,   34, -134,  157,
461cabdff1aSopenharmony_ci    104,  -84,  -34, -115,   23, -101,    3,   45,
462cabdff1aSopenharmony_ci   -101,  -16,  -59,   28,  -45,  134,  -67,   22,
463cabdff1aSopenharmony_ci     61,  -29,  226,  -26,  -55, -179,  157,  -51,
464cabdff1aSopenharmony_ci   -220,  -93,  -37,   60,  118,   74,  -48,  -95,
465cabdff1aSopenharmony_ci   -181,  111,   36,  -52, -215,   78, -112,   39,
466cabdff1aSopenharmony_ci    -17,  -47, -223,   19,   12,  -98, -142,  130,
467cabdff1aSopenharmony_ci     54, -127,   21,  -12,   39,  -48,   12,  128,
468cabdff1aSopenharmony_ci      6, -167,   82, -102,  -79,   55,  -44,   48,
469cabdff1aSopenharmony_ci    -20,  -53,    8,  -61,   11,  -70, -157, -168,
470cabdff1aSopenharmony_ci     20,  -56,  -74,   78,   33,  -63, -173,   -2,
471cabdff1aSopenharmony_ci    -75,  -53, -146,   77,   66,  -29,    9,  -75,
472cabdff1aSopenharmony_ci     65,  119,  -43,   76,  233,   98,  125, -156,
473cabdff1aSopenharmony_ci    -27,   78,   -9,  170,  176,  143, -148,   -7,
474cabdff1aSopenharmony_ci     27, -136,    5,   27,   18,  139,  204,    7,
475cabdff1aSopenharmony_ci   -184, -197,   52,   -3,   78, -189,    8,  -65
476cabdff1aSopenharmony_ci};
477cabdff1aSopenharmony_ci#define QCELP_RATE_FULL_CODEBOOK_RATIO .01
478cabdff1aSopenharmony_ci
479cabdff1aSopenharmony_ci/**
480cabdff1aSopenharmony_ci * Circular codebook for rate 1/2 frames in x*2 form
481cabdff1aSopenharmony_ci *
482cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.6.1-1
483cabdff1aSopenharmony_ci */
484cabdff1aSopenharmony_cistatic const int8_t qcelp_rate_half_codebook[128] = {
485cabdff1aSopenharmony_ci     0, -4,  0, -3,  0,  0,  0,  0,
486cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  0,
487cabdff1aSopenharmony_ci     0, -3, -2,  0,  0,  0,  0,  0,
488cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  5,
489cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  4,  0,
490cabdff1aSopenharmony_ci     0,  3,  2,  0,  3,  4,  0,  0,
491cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  0,
492cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  3,  0,  0,
493cabdff1aSopenharmony_ci    -3,  3,  0,  0, -2,  0,  3,  0,
494cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0, -5,  0,
495cabdff1aSopenharmony_ci     0,  0,  0,  3,  0,  0,  0,  3,
496cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  4,
497cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  0,
498cabdff1aSopenharmony_ci     0,  3,  6, -3, -4,  0, -3, -3,
499cabdff1aSopenharmony_ci     3, -3,  0,  0,  0,  0,  0,  0,
500cabdff1aSopenharmony_ci     0,  0,  0,  0,  0,  0,  0,  0
501cabdff1aSopenharmony_ci};
502cabdff1aSopenharmony_ci#define QCELP_RATE_HALF_CODEBOOK_RATIO 0.5
503cabdff1aSopenharmony_ci
504cabdff1aSopenharmony_ci/**
505cabdff1aSopenharmony_ci * sqrt(1.887) is the maximum of the pseudorandom
506cabdff1aSopenharmony_ci * white sequence used to generate the scaled codebook
507cabdff1aSopenharmony_ci * vector for bitrate 1/4.
508cabdff1aSopenharmony_ci *
509cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.8.1.2
510cabdff1aSopenharmony_ci */
511cabdff1aSopenharmony_ci#define QCELP_SQRT1887 1.373681186
512cabdff1aSopenharmony_ci
513cabdff1aSopenharmony_ci/**
514cabdff1aSopenharmony_ci * Table for impulse response of BPF used to filter
515cabdff1aSopenharmony_ci * the white excitation for bitrate 1/4 synthesis
516cabdff1aSopenharmony_ci *
517cabdff1aSopenharmony_ci * Only half the tables are needed because of symmetry.
518cabdff1aSopenharmony_ci *
519cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.8.1.2-1.1
520cabdff1aSopenharmony_ci */
521cabdff1aSopenharmony_cistatic const double qcelp_rnd_fir_coefs[11] = {
522cabdff1aSopenharmony_ci  -1.344519e-1, 1.735384e-2, -6.905826e-2, 2.434368e-2,
523cabdff1aSopenharmony_ci  -8.210701e-2, 3.041388e-2, -9.251384e-2, 3.501983e-2,
524cabdff1aSopenharmony_ci  -9.918777e-2, 3.749518e-2,  8.985137e-1
525cabdff1aSopenharmony_ci};
526cabdff1aSopenharmony_ci
527cabdff1aSopenharmony_ci/**
528cabdff1aSopenharmony_ci * This spread factor is used, for bitrate 1/8 and I_F_Q,
529cabdff1aSopenharmony_ci * to force LSP frequencies to be at least 80 Hz apart.
530cabdff1aSopenharmony_ci *
531cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.3.3.2
532cabdff1aSopenharmony_ci */
533cabdff1aSopenharmony_ci#define QCELP_LSP_SPREAD_FACTOR 0.02
534cabdff1aSopenharmony_ci
535cabdff1aSopenharmony_ci/**
536cabdff1aSopenharmony_ci * Predictor coefficient for the conversion of LSP codes
537cabdff1aSopenharmony_ci * to LSP frequencies for 1/8 and I_F_Q
538cabdff1aSopenharmony_ci *
539cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.3.2.7-2
540cabdff1aSopenharmony_ci */
541cabdff1aSopenharmony_ci#define QCELP_LSP_OCTAVE_PREDICTOR 29.0/32
542cabdff1aSopenharmony_ci
543cabdff1aSopenharmony_ci/**
544cabdff1aSopenharmony_ci * Initial coefficient to perform bandwidth expansion on LPC
545cabdff1aSopenharmony_ci *
546cabdff1aSopenharmony_ci * @note: 0.9883 looks like an approximation of 253/256.
547cabdff1aSopenharmony_ci *
548cabdff1aSopenharmony_ci * TIA/EIA/IS-733 2.4.3.3.6 6
549cabdff1aSopenharmony_ci */
550cabdff1aSopenharmony_ci#define QCELP_BANDWIDTH_EXPANSION_COEFF 0.9883
551cabdff1aSopenharmony_ci
552cabdff1aSopenharmony_ci#endif /* AVCODEC_QCELPDATA_H */
553