2020-09-30 16:53:55 +02:00

289 lines
7.0 KiB
C

/*
**
** File: "cst_lbc.h"
**
** Description: This file contains global definition of the SG15
** LBC Coder for 6.3/5.3 kbps.
**
*/
/*
ITU-T G.723 Floating Point Speech Coder ANSI C Source Code. Version 3.01
Original fixed-point code copyright (c) 1995,
AudioCodes, DSP Group, France Telecom, Universite de Sherbrooke.
All rights reserved.
Floating-point code copyright (c) 1995,
Intel Corporation and France Telecom (CNET).
All rights reserved.
*/
/*
This file contains global definition of the SG15
LBR Coder for 6.4/5.3 kbps.
*/
#include "typedef.h"
#define False 0
#define True 1
//#if NOTMINI
#define FALSE 0
#define TRUE 1
//#endif
/* Definition of the working mode */
enum Wmode { Both, Cod, Dec } ;
/* Coder rate */
//enum Crate { Silent, Rate53, Rate63, Lost } ;
/* Changed in V4.1 */
enum Crate { Rate63, Rate53, Silent, Lost } ;
/* Coder global constants */
#define Frame 240
#define LpcFrame 180
#define SubFrames 4
#define SubFrLen (Frame/SubFrames)
#define LpcOrder 10
#define RidgeFact 10
#define CosineTableSize 512
#define PreCoef -0.25f
#define LspPrd0 12288
#define LspPrd1 23552
#define LspPred0 (12.0f/32.0f)
#define LspPred1 (23.0f/32.0f)
#define LspQntBands 3
#define LspCbSize 256
#define LspCbBits 8
#define PitchMin 18
#define PitchMax (PitchMin+127)
#define PwRange 3
#define ClPitchOrd 5
#define Pstep 1
#define NbFilt085 85
#define NbFilt170 170
#define Sgrid 2
#define MaxPulseNum 6
#define MlqSteps 2
/* acelp constants */
#define SubFrLen2 (SubFrLen +4)
#define DIM_RR 416
#define NB_POS 8
#define STEP 8
#define MSIZE 64
#define threshold 0.5f
#define max_time 120
#define NumOfGainLev 24
#define ErrMaxNum 3
/* Taming constants */
#define NbFilt085_min 51
#define NbFilt170_min 93
#define SizErr 5
#define Err0 0.00000381464f
#define ThreshErr 128.0f
#define SRCSTATELEN 16 // sample rate conversion state length
#ifdef LOG_ENCODE_TIMINGS_ON // { LOG_ENCODE_TIMINGS_ON
/* Encoder Timing Data - per frame
*/
typedef struct {
unsigned long dwEncode;
#ifdef DETAILED_ENCODE_TIMINGS_ON // { DETAILED_ENCODE_TIMINGS_ON
unsigned long dwRem_Dc;
unsigned long dwComp_Lpc;
unsigned long dwAtoLsp;
unsigned long dwLsp_Qnt;
unsigned long dwLsp_Inq;
unsigned long dwLsp_Int;
unsigned long dwMem_Shift;
unsigned long dwWght_Lpc;
unsigned long dwError_Wght;
unsigned long dwFew_Lps_In_Coder;
unsigned long dwFilt_Pw;
unsigned long dwComp_Ir;
unsigned long dwSub_Ring;
unsigned long dwFind_Acbk;
unsigned long dwFind_Fcbk;
unsigned long dwDecode_Acbk;
unsigned long dwReconstr_Excit;
unsigned long dwUpd_Ring;
unsigned long dwLine_Pack;
#endif // } DETAILED_ENCODE_TIMINGS_ON
} ENC_TIMING_INFO;
// 2057 frames will allow us to store stats
// for all of our Geo08kHz16BitMonoPCM.wav
// test file...
#define ENC_TIMING_INFO_FRAME_COUNT 2057
#endif // } LOG_ENCODE_TIMINGS_ON
#ifdef LOG_DECODE_TIMINGS_ON // { LOG_DECODE_TIMINGS_ON
/* Encoder Timing Data - per frame
*/
typedef struct {
unsigned long dwDecode;
#ifdef DETAILED_DECODE_TIMINGS_ON // { DETAILED_DECODE_TIMINGS_ON
unsigned long dwLine_Unpk;
unsigned long dwLsp_Inq;
unsigned long dwLsp_Int;
unsigned long dwVariousD;
unsigned long dwFcbk_UnpkD;
unsigned long dwDecod_AcbkD;
unsigned long dwComp_Info;
unsigned long dwRegen;
unsigned long dwSynt;
#endif // } DETAILED_DECODE_TIMINGS_ON
} DEC_TIMING_INFO;
// 2057 frames will allow us to store stats
// for all of our Geo08kHz16BitMonoPCM.wav
// test file...
#define DEC_TIMING_INFO_FRAME_COUNT 2057
#endif // } LOG_DECODE_TIMINGS_ON
/*
Used structures
*/
typedef struct {
float HpfZdl;
float HpfPdl;
/* Lsp previous vector */
float PrevLsp[LpcOrder] ;
/* All pitch operation buffers */
float PrevWgt[PitchMax] ;
float PrevErr[PitchMax] ;
float PrevExc[PitchMax] ;
/* Requered memory for the delay */
float PrevDat[LpcFrame-SubFrLen] ;
/* Used delay lines */
float WghtFirDl[2*LpcOrder];
float WghtIirDl[2*LpcOrder];
float RingFirDl[2*LpcOrder];
float RingIirDl[2*LpcOrder];
/* For taming procedure */
int SinDet;
float Err[SizErr];
//These entries are not part of the ITU 723 std.
int p;
int q;
int srccount; // sampling rate conversion count
short srcstate[SRCSTATELEN]; // sampling rate conversion state
// Lsp previous vector
/* All pitch operation buffers */
int VadAct;
Flag UseHp;
enum Crate WrkRate;
int quality;
#ifdef LOG_ENCODE_TIMINGS_ON // { LOG_ENCODE_TIMINGS_ON
ENC_TIMING_INFO EncTimingInfo[ENC_TIMING_INFO_FRAME_COUNT];
unsigned long dwStatFrameCount;
int bTimingThisFrame;
unsigned long dwStartLow;
unsigned long dwStartHigh;
#endif // } LOG_ENCODE_TIMINGS_ON
} CODDEF ;
typedef struct {
int Ecount;
float InterGain;
int InterIndx;
int Rseed;
// Lsp previous vector
// Name changed to avoid confusion with encoder
// previous LSPs
//float PrevLSP[LpcOrder];
float dPrevLsp[LpcOrder];
/* All pitch operation buffers */
// Name changed to avoid confusion with encoder
// previous excitation
//float PrevExc[PitchMax];
float dPrevExc[PitchMax] ;
/* Used delay lines */
float SyntIirDl[2*LpcOrder] ;
//These entries are not part of the ITU 723 std.
int dp;
int dq;
int srccount; // sampling rate conversion count
short srcstate[SRCSTATELEN]; // sampling rate conversion state
short srcbuff[480]; // sampling rate conversion buffer
int i;
int VadAct;
Flag UsePf;
enum Crate WrkRate;
#ifdef LOG_DECODE_TIMINGS_ON // { LOG_DECODE_TIMINGS_ON
DEC_TIMING_INFO DecTimingInfo[DEC_TIMING_INFO_FRAME_COUNT];
unsigned long dwStatFrameCount;
int bTimingThisFrame;
unsigned long dwStartLow;
unsigned long dwStartHigh;
#endif // } LOG_DECODE_TIMINGS_ON
} DECDEF ;
typedef struct {
int AcLg;
int AcGn;
int Mamp;
int Grid;
int Tran;
int Pamp;
Word32 Ppos;
} SFSDEF;
typedef struct {
int Crc ;
Word32 LspId ;
int Olp[SubFrames/2] ;
SFSDEF Sfs[SubFrames] ;
} LINEDEF ;
typedef struct {
int Indx;
float Gain;
} PWDEF;
typedef struct {
float MaxErr ;
int GridId ;
int MampId ;
int UseTrn ;
int Ploc[MaxPulseNum] ;
float Pamp[MaxPulseNum] ;
} BESTDEF ;
/* Prototype used for the ACELP codebook */