1*a58d3d2aSXin Li /*********************************************************************** 2*a58d3d2aSXin Li Copyright (c) 2006-2011, Skype Limited. All rights reserved. 3*a58d3d2aSXin Li Redistribution and use in source and binary forms, with or without 4*a58d3d2aSXin Li modification, are permitted provided that the following conditions 5*a58d3d2aSXin Li are met: 6*a58d3d2aSXin Li - Redistributions of source code must retain the above copyright notice, 7*a58d3d2aSXin Li this list of conditions and the following disclaimer. 8*a58d3d2aSXin Li - Redistributions in binary form must reproduce the above copyright 9*a58d3d2aSXin Li notice, this list of conditions and the following disclaimer in the 10*a58d3d2aSXin Li documentation and/or other materials provided with the distribution. 11*a58d3d2aSXin Li - Neither the name of Internet Society, IETF or IETF Trust, nor the 12*a58d3d2aSXin Li names of specific contributors, may be used to endorse or promote 13*a58d3d2aSXin Li products derived from this software without specific prior written 14*a58d3d2aSXin Li permission. 15*a58d3d2aSXin Li THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 16*a58d3d2aSXin Li AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17*a58d3d2aSXin Li IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18*a58d3d2aSXin Li ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 19*a58d3d2aSXin Li LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 20*a58d3d2aSXin Li CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 21*a58d3d2aSXin Li SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 22*a58d3d2aSXin Li INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 23*a58d3d2aSXin Li CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 24*a58d3d2aSXin Li ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 25*a58d3d2aSXin Li POSSIBILITY OF SUCH DAMAGE. 26*a58d3d2aSXin Li ***********************************************************************/ 27*a58d3d2aSXin Li 28*a58d3d2aSXin Li #ifndef SILK_STRUCTS_FLP_H 29*a58d3d2aSXin Li #define SILK_STRUCTS_FLP_H 30*a58d3d2aSXin Li 31*a58d3d2aSXin Li #include "typedef.h" 32*a58d3d2aSXin Li #include "main.h" 33*a58d3d2aSXin Li #include "structs.h" 34*a58d3d2aSXin Li 35*a58d3d2aSXin Li #ifdef __cplusplus 36*a58d3d2aSXin Li extern "C" 37*a58d3d2aSXin Li { 38*a58d3d2aSXin Li #endif 39*a58d3d2aSXin Li 40*a58d3d2aSXin Li /********************************/ 41*a58d3d2aSXin Li /* Noise shaping analysis state */ 42*a58d3d2aSXin Li /********************************/ 43*a58d3d2aSXin Li typedef struct { 44*a58d3d2aSXin Li opus_int8 LastGainIndex; 45*a58d3d2aSXin Li silk_float HarmShapeGain_smth; 46*a58d3d2aSXin Li silk_float Tilt_smth; 47*a58d3d2aSXin Li } silk_shape_state_FLP; 48*a58d3d2aSXin Li 49*a58d3d2aSXin Li /********************************/ 50*a58d3d2aSXin Li /* Encoder state FLP */ 51*a58d3d2aSXin Li /********************************/ 52*a58d3d2aSXin Li typedef struct { 53*a58d3d2aSXin Li silk_encoder_state sCmn; /* Common struct, shared with fixed-point code */ 54*a58d3d2aSXin Li silk_shape_state_FLP sShape; /* Noise shaping state */ 55*a58d3d2aSXin Li 56*a58d3d2aSXin Li /* Buffer for find pitch and noise shape analysis */ 57*a58d3d2aSXin Li silk_float x_buf[ 2 * MAX_FRAME_LENGTH + LA_SHAPE_MAX ];/* Buffer for find pitch and noise shape analysis */ 58*a58d3d2aSXin Li silk_float LTPCorr; /* Normalized correlation from pitch lag estimator */ 59*a58d3d2aSXin Li } silk_encoder_state_FLP; 60*a58d3d2aSXin Li 61*a58d3d2aSXin Li /************************/ 62*a58d3d2aSXin Li /* Encoder control FLP */ 63*a58d3d2aSXin Li /************************/ 64*a58d3d2aSXin Li typedef struct { 65*a58d3d2aSXin Li /* Prediction and coding parameters */ 66*a58d3d2aSXin Li silk_float Gains[ MAX_NB_SUBFR ]; 67*a58d3d2aSXin Li silk_float PredCoef[ 2 ][ MAX_LPC_ORDER ]; /* holds interpolated and final coefficients */ 68*a58d3d2aSXin Li silk_float LTPCoef[LTP_ORDER * MAX_NB_SUBFR]; 69*a58d3d2aSXin Li silk_float LTP_scale; 70*a58d3d2aSXin Li opus_int pitchL[ MAX_NB_SUBFR ]; 71*a58d3d2aSXin Li 72*a58d3d2aSXin Li /* Noise shaping parameters */ 73*a58d3d2aSXin Li silk_float AR[ MAX_NB_SUBFR * MAX_SHAPE_LPC_ORDER ]; 74*a58d3d2aSXin Li silk_float LF_MA_shp[ MAX_NB_SUBFR ]; 75*a58d3d2aSXin Li silk_float LF_AR_shp[ MAX_NB_SUBFR ]; 76*a58d3d2aSXin Li silk_float Tilt[ MAX_NB_SUBFR ]; 77*a58d3d2aSXin Li silk_float HarmShapeGain[ MAX_NB_SUBFR ]; 78*a58d3d2aSXin Li silk_float Lambda; 79*a58d3d2aSXin Li silk_float input_quality; 80*a58d3d2aSXin Li silk_float coding_quality; 81*a58d3d2aSXin Li 82*a58d3d2aSXin Li /* Measures */ 83*a58d3d2aSXin Li silk_float predGain; 84*a58d3d2aSXin Li silk_float LTPredCodGain; 85*a58d3d2aSXin Li silk_float ResNrg[ MAX_NB_SUBFR ]; /* Residual energy per subframe */ 86*a58d3d2aSXin Li 87*a58d3d2aSXin Li /* Parameters for CBR mode */ 88*a58d3d2aSXin Li opus_int32 GainsUnq_Q16[ MAX_NB_SUBFR ]; 89*a58d3d2aSXin Li opus_int8 lastGainIndexPrev; 90*a58d3d2aSXin Li } silk_encoder_control_FLP; 91*a58d3d2aSXin Li 92*a58d3d2aSXin Li /************************/ 93*a58d3d2aSXin Li /* Encoder Super Struct */ 94*a58d3d2aSXin Li /************************/ 95*a58d3d2aSXin Li typedef struct { 96*a58d3d2aSXin Li silk_encoder_state_FLP state_Fxx[ ENCODER_NUM_CHANNELS ]; 97*a58d3d2aSXin Li stereo_enc_state sStereo; 98*a58d3d2aSXin Li opus_int32 nBitsUsedLBRR; 99*a58d3d2aSXin Li opus_int32 nBitsExceeded; 100*a58d3d2aSXin Li opus_int nChannelsAPI; 101*a58d3d2aSXin Li opus_int nChannelsInternal; 102*a58d3d2aSXin Li opus_int nPrevChannelsInternal; 103*a58d3d2aSXin Li opus_int timeSinceSwitchAllowed_ms; 104*a58d3d2aSXin Li opus_int allowBandwidthSwitch; 105*a58d3d2aSXin Li opus_int prev_decode_only_middle; 106*a58d3d2aSXin Li } silk_encoder; 107*a58d3d2aSXin Li 108*a58d3d2aSXin Li #ifdef __cplusplus 109*a58d3d2aSXin Li } 110*a58d3d2aSXin Li #endif 111*a58d3d2aSXin Li 112*a58d3d2aSXin Li #endif 113