| /* |
| * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| /****************************************************************** |
| |
| iLBC Speech Coder ANSI-C Source Code |
| |
| define.h |
| |
| ******************************************************************/ |
| #ifndef MODULES_AUDIO_CODING_CODECS_ILBC_MAIN_SOURCE_DEFINES_H_ |
| #define MODULES_AUDIO_CODING_CODECS_ILBC_MAIN_SOURCE_DEFINES_H_ |
| |
| #include <string.h> |
| |
| #include "common_audio/signal_processing/include/signal_processing_library.h" |
| #include "typedefs.h" // NOLINT(build/include) |
| |
| /* general codec settings */ |
| |
| #define FS 8000 |
| #define BLOCKL_20MS 160 |
| #define BLOCKL_30MS 240 |
| #define BLOCKL_MAX 240 |
| #define NSUB_20MS 4 |
| #define NSUB_30MS 6 |
| #define NSUB_MAX 6 |
| #define NASUB_20MS 2 |
| #define NASUB_30MS 4 |
| #define NASUB_MAX 4 |
| #define SUBL 40 |
| #define STATE_LEN 80 |
| #define STATE_SHORT_LEN_30MS 58 |
| #define STATE_SHORT_LEN_20MS 57 |
| |
| /* LPC settings */ |
| |
| #define LPC_FILTERORDER 10 |
| #define LPC_LOOKBACK 60 |
| #define LPC_N_20MS 1 |
| #define LPC_N_30MS 2 |
| #define LPC_N_MAX 2 |
| #define LPC_ASYMDIFF 20 |
| #define LSF_NSPLIT 3 |
| #define LSF_NUMBER_OF_STEPS 4 |
| #define LPC_HALFORDER 5 |
| #define COS_GRID_POINTS 60 |
| |
| /* cb settings */ |
| |
| #define CB_NSTAGES 3 |
| #define CB_EXPAND 2 |
| #define CB_MEML 147 |
| #define CB_FILTERLEN (2 * 4) |
| #define CB_HALFFILTERLEN 4 |
| #define CB_RESRANGE 34 |
| #define CB_MAXGAIN_FIXQ6 83 /* error = -0.24% */ |
| #define CB_MAXGAIN_FIXQ14 21299 |
| |
| /* enhancer */ |
| |
| #define ENH_BLOCKL 80 /* block length */ |
| #define ENH_BLOCKL_HALF (ENH_BLOCKL / 2) |
| #define ENH_HL \ |
| 3 /* 2*ENH_HL+1 is number blocks \ |
| in said second \ |
| sequence */ |
| #define ENH_SLOP \ |
| 2 /* max difference estimated and \ |
| correct pitch period */ |
| #define ENH_PLOCSL \ |
| 8 /* pitch-estimates and \ |
| pitch-locations buffer \ |
| length */ |
| #define ENH_OVERHANG 2 |
| #define ENH_UPS0 4 /* upsampling rate */ |
| #define ENH_FL0 3 /* 2*FLO+1 is the length of each filter */ |
| #define ENH_FLO_MULT2_PLUS1 7 |
| #define ENH_VECTL (ENH_BLOCKL + 2 * ENH_FL0) |
| #define ENH_CORRDIM (2 * ENH_SLOP + 1) |
| #define ENH_NBLOCKS (BLOCKL / ENH_BLOCKL) |
| #define ENH_NBLOCKS_EXTRA 5 |
| #define ENH_NBLOCKS_TOT 8 /* ENH_NBLOCKS+ENH_NBLOCKS_EXTRA */ |
| #define ENH_BUFL (ENH_NBLOCKS_TOT) * ENH_BLOCKL |
| #define ENH_BUFL_FILTEROVERHEAD 3 |
| #define ENH_A0 819 /* Q14 */ |
| #define ENH_A0_MINUS_A0A0DIV4 848256041 /* Q34 */ |
| #define ENH_A0DIV2 26843546 /* Q30 */ |
| |
| /* PLC */ |
| |
| /* Down sampling */ |
| |
| #define FILTERORDER_DS_PLUS1 7 |
| #define DELAY_DS 3 |
| #define FACTOR_DS 2 |
| |
| /* bit stream defs */ |
| |
| #define NO_OF_BYTES_20MS 38 |
| #define NO_OF_BYTES_30MS 50 |
| #define NO_OF_WORDS_20MS 19 |
| #define NO_OF_WORDS_30MS 25 |
| #define STATE_BITS 3 |
| #define BYTE_LEN 8 |
| #define ULP_CLASSES 3 |
| |
| /* help parameters */ |
| |
| #define TWO_PI_FIX 25736 /* Q12 */ |
| |
| /* Constants for codebook search and creation */ |
| |
| #define ST_MEM_L_TBL 85 |
| #define MEM_LF_TBL 147 |
| |
| /* Struct for the bits */ |
| typedef struct iLBC_bits_t_ { |
| int16_t lsf[LSF_NSPLIT * LPC_N_MAX]; |
| int16_t cb_index[CB_NSTAGES * (NASUB_MAX + 1)]; /* First CB_NSTAGES values |
| contains extra CB index */ |
| int16_t gain_index[CB_NSTAGES * (NASUB_MAX + 1)]; /* First CB_NSTAGES values |
| contains extra CB gain */ |
| size_t idxForMax; |
| int16_t state_first; |
| int16_t idxVec[STATE_SHORT_LEN_30MS]; |
| int16_t firstbits; |
| size_t startIdx; |
| } iLBC_bits; |
| |
| /* type definition encoder instance */ |
| typedef struct IlbcEncoder_ { |
| /* flag for frame size mode */ |
| int16_t mode; |
| |
| /* basic parameters for different frame sizes */ |
| size_t blockl; |
| size_t nsub; |
| int16_t nasub; |
| size_t no_of_bytes, no_of_words; |
| int16_t lpc_n; |
| size_t state_short_len; |
| |
| /* analysis filter state */ |
| int16_t anaMem[LPC_FILTERORDER]; |
| |
| /* Fix-point old lsf parameters for interpolation */ |
| int16_t lsfold[LPC_FILTERORDER]; |
| int16_t lsfdeqold[LPC_FILTERORDER]; |
| |
| /* signal buffer for LP analysis */ |
| int16_t lpc_buffer[LPC_LOOKBACK + BLOCKL_MAX]; |
| |
| /* state of input HP filter */ |
| int16_t hpimemx[2]; |
| int16_t hpimemy[4]; |
| |
| #ifdef SPLIT_10MS |
| int16_t weightdenumbuf[66]; |
| int16_t past_samples[160]; |
| uint16_t bytes[25]; |
| int16_t section; |
| int16_t Nfor_flag; |
| int16_t Nback_flag; |
| int16_t start_pos; |
| size_t diff; |
| #endif |
| |
| } IlbcEncoder; |
| |
| /* type definition decoder instance */ |
| typedef struct IlbcDecoder_ { |
| /* flag for frame size mode */ |
| int16_t mode; |
| |
| /* basic parameters for different frame sizes */ |
| size_t blockl; |
| size_t nsub; |
| int16_t nasub; |
| size_t no_of_bytes, no_of_words; |
| int16_t lpc_n; |
| size_t state_short_len; |
| |
| /* synthesis filter state */ |
| int16_t syntMem[LPC_FILTERORDER]; |
| |
| /* old LSF for interpolation */ |
| int16_t lsfdeqold[LPC_FILTERORDER]; |
| |
| /* pitch lag estimated in enhancer and used in PLC */ |
| size_t last_lag; |
| |
| /* PLC state information */ |
| int consPLICount, prev_enh_pl; |
| int16_t perSquare; |
| |
| int16_t prevScale, prevPLI; |
| size_t prevLag; |
| int16_t prevLpc[LPC_FILTERORDER + 1]; |
| int16_t prevResidual[NSUB_MAX * SUBL]; |
| int16_t seed; |
| |
| /* previous synthesis filter parameters */ |
| |
| int16_t old_syntdenum[(LPC_FILTERORDER + 1) * NSUB_MAX]; |
| |
| /* state of output HP filter */ |
| int16_t hpimemx[2]; |
| int16_t hpimemy[4]; |
| |
| /* enhancer state information */ |
| int use_enhancer; |
| int16_t enh_buf[ENH_BUFL + ENH_BUFL_FILTEROVERHEAD]; |
| size_t enh_period[ENH_NBLOCKS_TOT]; |
| |
| } IlbcDecoder; |
| |
| #endif |