comparison intercom/ilbc/StateConstructW.c @ 2:13be24d74cd2

import intercom-0.4.1
author Peter Meerwald <pmeerw@cosy.sbg.ac.at>
date Fri, 25 Jun 2010 09:57:52 +0200 (2010-06-25)
parents
children
comparison
equal deleted inserted replaced
1:9cadc470e3da 2:13be24d74cd2
1
2 /******************************************************************
3
4 iLBC Speech Coder ANSI-C Source Code
5
6 StateConstructW.c
7
8 Copyright (C) The Internet Society (2004).
9 All Rights Reserved.
10
11 ******************************************************************/
12
13 #include <math.h>
14 #include <string.h>
15
16 #include "iLBC_define.h"
17 #include "constants.h"
18 #include "filter.h"
19
20 /*----------------------------------------------------------------*
21 * decoding of the start state
22 *---------------------------------------------------------------*/
23
24 void StateConstructW(int idxForMax, /* (i) 6-bit index for the quantization of
25 max amplitude */
26 int *idxVec, /* (i) vector of quantization indexes */
27 float *syntDenum, /* (i) synthesis filter denumerator */
28 float *out, /* (o) the decoded state vector */
29 int len /* (i) length of a state vector */
30 )
31 {
32 float maxVal, tmpbuf[LPC_FILTERORDER + 2 * STATE_LEN], *tmp,
33 numerator[LPC_FILTERORDER + 1];
34 float foutbuf[LPC_FILTERORDER + 2 * STATE_LEN], *fout;
35 int k, tmpi;
36
37 /* decoding of the maximum value */
38
39 maxVal = state_frgqTbl[idxForMax];
40 maxVal = (float) pow(10, maxVal) / (float) 4.5;
41
42 /* initialization of buffers and coefficients */
43
44 memset(tmpbuf, 0, LPC_FILTERORDER * sizeof(float));
45 memset(foutbuf, 0, LPC_FILTERORDER * sizeof(float));
46 for (k = 0; k < LPC_FILTERORDER; k++) {
47 numerator[k] = syntDenum[LPC_FILTERORDER - k];
48 }
49 numerator[LPC_FILTERORDER] = syntDenum[0];
50 tmp = &tmpbuf[LPC_FILTERORDER];
51 fout = &foutbuf[LPC_FILTERORDER];
52
53 /* decoding of the sample values */
54
55 for (k = 0; k < len; k++) {
56 tmpi = len - 1 - k;
57 /* maxVal = 1/scal */
58 tmp[k] = maxVal * state_sq3Tbl[idxVec[tmpi]];
59 }
60
61 /* circular convolution with all-pass filter */
62
63 memset(tmp + len, 0, len * sizeof(float));
64 ZeroPoleFilter(tmp, numerator, syntDenum, 2 * len,
65 LPC_FILTERORDER, fout);
66 for (k = 0; k < len; k++) {
67 out[k] = fout[len - 1 - k] + fout[2 * len - 1 - k];
68 }
69 }

Repositories maintained by Peter Meerwald, pmeerw@pmeerw.net.