123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 |
- /*
- * 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"
- /* 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
|