📄 dcodcbi.h
字号:
/**************************************************************************
*
* ROUTINE
* dcodcbi
*
* FUNCTION
* Decodes all code book indicies for a frame
*
*
* SYNOPSIS
* subroutine dcodcbi(cbbits,bitsum1,bitsum2,nn,cbi)
*
* formal
*
* data I/O
* name type type function
* -------------------------------------------------------------------
* cbbits int i number of bits for quantization
* bitsum1 int i number of bits for odd subframes
* bitsum2 int i number of bits for even subframes
* bitpointer int i/o number of bits used
* nn int i number of subframes/frame
* stream short i bit stream
* cbi int o vector of code book indicies
*
***************************************************************************
*
* DESCRIPTION
*
*
***************************************************************************
*
* CALLED BY
*
* celp
*
* CALLS
*
* unpack
*
***************************************************************************
*
* REFERENCES
*
*
**************************************************************************/
static void dcodcbi(int cbbits, int a_bitsum1, int a_bitsum2,
int *a_bitpointer, int nn, short a_stream[], int a_cbi[])
{
int i, l_pointer;
l_pointer = *a_bitpointer;
for (i = 0; i < nn; i++)
{
unpack(a_stream, cbbits, &a_cbi[i], &l_pointer);
a_cbi[i]++;
if (i == 0 || i == 2 || i == 4)
l_pointer += a_bitsum2 - cbbits;
else if (i == 1 || i == 3 || i == 5)
l_pointer += a_bitsum1 - cbbits;
else {
#ifdef CELPDIAG
fprintf(stderr, "dcodcbi: ***Error in decoding code book index\n");
#endif
CELP_ERROR(CELP_ERR_DCODCBI);
return;
}
}
*a_bitpointer += cbbits;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -