annotate src/opus-1.3/silk/define.h @ 169:223a55898ab9 tip default

Add null config files
author Chris Cannam <cannam@all-day-breakfast.com>
date Mon, 02 Mar 2020 14:03:47 +0000
parents 4664ac0c1032
children
rev   line source
cannam@154 1 /***********************************************************************
cannam@154 2 Copyright (c) 2006-2011, Skype Limited. All rights reserved.
cannam@154 3 Redistribution and use in source and binary forms, with or without
cannam@154 4 modification, are permitted provided that the following conditions
cannam@154 5 are met:
cannam@154 6 - Redistributions of source code must retain the above copyright notice,
cannam@154 7 this list of conditions and the following disclaimer.
cannam@154 8 - Redistributions in binary form must reproduce the above copyright
cannam@154 9 notice, this list of conditions and the following disclaimer in the
cannam@154 10 documentation and/or other materials provided with the distribution.
cannam@154 11 - Neither the name of Internet Society, IETF or IETF Trust, nor the
cannam@154 12 names of specific contributors, may be used to endorse or promote
cannam@154 13 products derived from this software without specific prior written
cannam@154 14 permission.
cannam@154 15 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
cannam@154 16 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
cannam@154 17 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
cannam@154 18 ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
cannam@154 19 LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
cannam@154 20 CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
cannam@154 21 SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
cannam@154 22 INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
cannam@154 23 CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
cannam@154 24 ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
cannam@154 25 POSSIBILITY OF SUCH DAMAGE.
cannam@154 26 ***********************************************************************/
cannam@154 27
cannam@154 28 #ifndef SILK_DEFINE_H
cannam@154 29 #define SILK_DEFINE_H
cannam@154 30
cannam@154 31 #include "errors.h"
cannam@154 32 #include "typedef.h"
cannam@154 33
cannam@154 34 #ifdef __cplusplus
cannam@154 35 extern "C"
cannam@154 36 {
cannam@154 37 #endif
cannam@154 38
cannam@154 39 /* Max number of encoder channels (1/2) */
cannam@154 40 #define ENCODER_NUM_CHANNELS 2
cannam@154 41 /* Number of decoder channels (1/2) */
cannam@154 42 #define DECODER_NUM_CHANNELS 2
cannam@154 43
cannam@154 44 #define MAX_FRAMES_PER_PACKET 3
cannam@154 45
cannam@154 46 /* Limits on bitrate */
cannam@154 47 #define MIN_TARGET_RATE_BPS 5000
cannam@154 48 #define MAX_TARGET_RATE_BPS 80000
cannam@154 49
cannam@154 50 /* LBRR thresholds */
cannam@154 51 #define LBRR_NB_MIN_RATE_BPS 12000
cannam@154 52 #define LBRR_MB_MIN_RATE_BPS 14000
cannam@154 53 #define LBRR_WB_MIN_RATE_BPS 16000
cannam@154 54
cannam@154 55 /* DTX settings */
cannam@154 56 #define NB_SPEECH_FRAMES_BEFORE_DTX 10 /* eq 200 ms */
cannam@154 57 #define MAX_CONSECUTIVE_DTX 20 /* eq 400 ms */
cannam@154 58 #define DTX_ACTIVITY_THRESHOLD 0.1f
cannam@154 59
cannam@154 60 /* VAD decision */
cannam@154 61 #define VAD_NO_DECISION -1
cannam@154 62 #define VAD_NO_ACTIVITY 0
cannam@154 63 #define VAD_ACTIVITY 1
cannam@154 64
cannam@154 65 /* Maximum sampling frequency */
cannam@154 66 #define MAX_FS_KHZ 16
cannam@154 67 #define MAX_API_FS_KHZ 48
cannam@154 68
cannam@154 69 /* Signal types */
cannam@154 70 #define TYPE_NO_VOICE_ACTIVITY 0
cannam@154 71 #define TYPE_UNVOICED 1
cannam@154 72 #define TYPE_VOICED 2
cannam@154 73
cannam@154 74 /* Conditional coding types */
cannam@154 75 #define CODE_INDEPENDENTLY 0
cannam@154 76 #define CODE_INDEPENDENTLY_NO_LTP_SCALING 1
cannam@154 77 #define CODE_CONDITIONALLY 2
cannam@154 78
cannam@154 79 /* Settings for stereo processing */
cannam@154 80 #define STEREO_QUANT_TAB_SIZE 16
cannam@154 81 #define STEREO_QUANT_SUB_STEPS 5
cannam@154 82 #define STEREO_INTERP_LEN_MS 8 /* must be even */
cannam@154 83 #define STEREO_RATIO_SMOOTH_COEF 0.01 /* smoothing coef for signal norms and stereo width */
cannam@154 84
cannam@154 85 /* Range of pitch lag estimates */
cannam@154 86 #define PITCH_EST_MIN_LAG_MS 2 /* 2 ms -> 500 Hz */
cannam@154 87 #define PITCH_EST_MAX_LAG_MS 18 /* 18 ms -> 56 Hz */
cannam@154 88
cannam@154 89 /* Maximum number of subframes */
cannam@154 90 #define MAX_NB_SUBFR 4
cannam@154 91
cannam@154 92 /* Number of samples per frame */
cannam@154 93 #define LTP_MEM_LENGTH_MS 20
cannam@154 94 #define SUB_FRAME_LENGTH_MS 5
cannam@154 95 #define MAX_SUB_FRAME_LENGTH ( SUB_FRAME_LENGTH_MS * MAX_FS_KHZ )
cannam@154 96 #define MAX_FRAME_LENGTH_MS ( SUB_FRAME_LENGTH_MS * MAX_NB_SUBFR )
cannam@154 97 #define MAX_FRAME_LENGTH ( MAX_FRAME_LENGTH_MS * MAX_FS_KHZ )
cannam@154 98
cannam@154 99 /* Milliseconds of lookahead for pitch analysis */
cannam@154 100 #define LA_PITCH_MS 2
cannam@154 101 #define LA_PITCH_MAX ( LA_PITCH_MS * MAX_FS_KHZ )
cannam@154 102
cannam@154 103 /* Order of LPC used in find pitch */
cannam@154 104 #define MAX_FIND_PITCH_LPC_ORDER 16
cannam@154 105
cannam@154 106 /* Length of LPC window used in find pitch */
cannam@154 107 #define FIND_PITCH_LPC_WIN_MS ( 20 + (LA_PITCH_MS << 1) )
cannam@154 108 #define FIND_PITCH_LPC_WIN_MS_2_SF ( 10 + (LA_PITCH_MS << 1) )
cannam@154 109 #define FIND_PITCH_LPC_WIN_MAX ( FIND_PITCH_LPC_WIN_MS * MAX_FS_KHZ )
cannam@154 110
cannam@154 111 /* Milliseconds of lookahead for noise shape analysis */
cannam@154 112 #define LA_SHAPE_MS 5
cannam@154 113 #define LA_SHAPE_MAX ( LA_SHAPE_MS * MAX_FS_KHZ )
cannam@154 114
cannam@154 115 /* Maximum length of LPC window used in noise shape analysis */
cannam@154 116 #define SHAPE_LPC_WIN_MAX ( 15 * MAX_FS_KHZ )
cannam@154 117
cannam@154 118 /* dB level of lowest gain quantization level */
cannam@154 119 #define MIN_QGAIN_DB 2
cannam@154 120 /* dB level of highest gain quantization level */
cannam@154 121 #define MAX_QGAIN_DB 88
cannam@154 122 /* Number of gain quantization levels */
cannam@154 123 #define N_LEVELS_QGAIN 64
cannam@154 124 /* Max increase in gain quantization index */
cannam@154 125 #define MAX_DELTA_GAIN_QUANT 36
cannam@154 126 /* Max decrease in gain quantization index */
cannam@154 127 #define MIN_DELTA_GAIN_QUANT -4
cannam@154 128
cannam@154 129 /* Quantization offsets (multiples of 4) */
cannam@154 130 #define OFFSET_VL_Q10 32
cannam@154 131 #define OFFSET_VH_Q10 100
cannam@154 132 #define OFFSET_UVL_Q10 100
cannam@154 133 #define OFFSET_UVH_Q10 240
cannam@154 134
cannam@154 135 #define QUANT_LEVEL_ADJUST_Q10 80
cannam@154 136
cannam@154 137 /* Maximum numbers of iterations used to stabilize an LPC vector */
cannam@154 138 #define MAX_LPC_STABILIZE_ITERATIONS 16
cannam@154 139 #define MAX_PREDICTION_POWER_GAIN 1e4f
cannam@154 140 #define MAX_PREDICTION_POWER_GAIN_AFTER_RESET 1e2f
cannam@154 141
cannam@154 142 #define MAX_LPC_ORDER 16
cannam@154 143 #define MIN_LPC_ORDER 10
cannam@154 144
cannam@154 145 /* Find Pred Coef defines */
cannam@154 146 #define LTP_ORDER 5
cannam@154 147
cannam@154 148 /* LTP quantization settings */
cannam@154 149 #define NB_LTP_CBKS 3
cannam@154 150
cannam@154 151 /* Flag to use harmonic noise shaping */
cannam@154 152 #define USE_HARM_SHAPING 1
cannam@154 153
cannam@154 154 /* Max LPC order of noise shaping filters */
cannam@154 155 #define MAX_SHAPE_LPC_ORDER 24
cannam@154 156
cannam@154 157 #define HARM_SHAPE_FIR_TAPS 3
cannam@154 158
cannam@154 159 /* Maximum number of delayed decision states */
cannam@154 160 #define MAX_DEL_DEC_STATES 4
cannam@154 161
cannam@154 162 #define LTP_BUF_LENGTH 512
cannam@154 163 #define LTP_MASK ( LTP_BUF_LENGTH - 1 )
cannam@154 164
cannam@154 165 #define DECISION_DELAY 40
cannam@154 166
cannam@154 167 /* Number of subframes for excitation entropy coding */
cannam@154 168 #define SHELL_CODEC_FRAME_LENGTH 16
cannam@154 169 #define LOG2_SHELL_CODEC_FRAME_LENGTH 4
cannam@154 170 #define MAX_NB_SHELL_BLOCKS ( MAX_FRAME_LENGTH / SHELL_CODEC_FRAME_LENGTH )
cannam@154 171
cannam@154 172 /* Number of rate levels, for entropy coding of excitation */
cannam@154 173 #define N_RATE_LEVELS 10
cannam@154 174
cannam@154 175 /* Maximum sum of pulses per shell coding frame */
cannam@154 176 #define SILK_MAX_PULSES 16
cannam@154 177
cannam@154 178 #define MAX_MATRIX_SIZE MAX_LPC_ORDER /* Max of LPC Order and LTP order */
cannam@154 179
cannam@154 180 # define NSQ_LPC_BUF_LENGTH MAX_LPC_ORDER
cannam@154 181
cannam@154 182 /***************************/
cannam@154 183 /* Voice activity detector */
cannam@154 184 /***************************/
cannam@154 185 #define VAD_N_BANDS 4
cannam@154 186
cannam@154 187 #define VAD_INTERNAL_SUBFRAMES_LOG2 2
cannam@154 188 #define VAD_INTERNAL_SUBFRAMES ( 1 << VAD_INTERNAL_SUBFRAMES_LOG2 )
cannam@154 189
cannam@154 190 #define VAD_NOISE_LEVEL_SMOOTH_COEF_Q16 1024 /* Must be < 4096 */
cannam@154 191 #define VAD_NOISE_LEVELS_BIAS 50
cannam@154 192
cannam@154 193 /* Sigmoid settings */
cannam@154 194 #define VAD_NEGATIVE_OFFSET_Q5 128 /* sigmoid is 0 at -128 */
cannam@154 195 #define VAD_SNR_FACTOR_Q16 45000
cannam@154 196
cannam@154 197 /* smoothing for SNR measurement */
cannam@154 198 #define VAD_SNR_SMOOTH_COEF_Q18 4096
cannam@154 199
cannam@154 200 /* Size of the piecewise linear cosine approximation table for the LSFs */
cannam@154 201 #define LSF_COS_TAB_SZ_FIX 128
cannam@154 202
cannam@154 203 /******************/
cannam@154 204 /* NLSF quantizer */
cannam@154 205 /******************/
cannam@154 206 #define NLSF_W_Q 2
cannam@154 207 #define NLSF_VQ_MAX_VECTORS 32
cannam@154 208 #define NLSF_QUANT_MAX_AMPLITUDE 4
cannam@154 209 #define NLSF_QUANT_MAX_AMPLITUDE_EXT 10
cannam@154 210 #define NLSF_QUANT_LEVEL_ADJ 0.1
cannam@154 211 #define NLSF_QUANT_DEL_DEC_STATES_LOG2 2
cannam@154 212 #define NLSF_QUANT_DEL_DEC_STATES ( 1 << NLSF_QUANT_DEL_DEC_STATES_LOG2 )
cannam@154 213
cannam@154 214 /* Transition filtering for mode switching */
cannam@154 215 #define TRANSITION_TIME_MS 5120 /* 5120 = 64 * FRAME_LENGTH_MS * ( TRANSITION_INT_NUM - 1 ) = 64*(20*4)*/
cannam@154 216 #define TRANSITION_NB 3 /* Hardcoded in tables */
cannam@154 217 #define TRANSITION_NA 2 /* Hardcoded in tables */
cannam@154 218 #define TRANSITION_INT_NUM 5 /* Hardcoded in tables */
cannam@154 219 #define TRANSITION_FRAMES ( TRANSITION_TIME_MS / MAX_FRAME_LENGTH_MS )
cannam@154 220 #define TRANSITION_INT_STEPS ( TRANSITION_FRAMES / ( TRANSITION_INT_NUM - 1 ) )
cannam@154 221
cannam@154 222 /* BWE factors to apply after packet loss */
cannam@154 223 #define BWE_AFTER_LOSS_Q16 63570
cannam@154 224
cannam@154 225 /* Defines for CN generation */
cannam@154 226 #define CNG_BUF_MASK_MAX 255 /* 2^floor(log2(MAX_FRAME_LENGTH))-1 */
cannam@154 227 #define CNG_GAIN_SMTH_Q16 4634 /* 0.25^(1/4) */
cannam@154 228 #define CNG_NLSF_SMTH_Q16 16348 /* 0.25 */
cannam@154 229
cannam@154 230 #ifdef __cplusplus
cannam@154 231 }
cannam@154 232 #endif
cannam@154 233
cannam@154 234 #endif