00001
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 #ifndef SB_CELP_H
00037 #define SB_CELP_H
00038
00039 #include "modes.h"
00040 #include <speex/speex_bits.h>
00041 #include "nb_celp.h"
00042
00044 typedef struct SBEncState {
00045 const SpeexMode *mode;
00046 void *st_low;
00047 int full_frame_size;
00048 int frame_size;
00049 int subframeSize;
00050 int nbSubframes;
00051 int windowSize;
00052 int lpcSize;
00053 int bufSize;
00054 int first;
00055 float lag_factor;
00056 float lpc_floor;
00057 spx_word16_t gamma1;
00058 spx_word16_t gamma2;
00060 char *stack;
00061 spx_sig_t *x0d, *x1d;
00062 spx_sig_t *high;
00063 spx_sig_t *y0, *y1;
00064 spx_word16_t *h0_mem, *h1_mem;
00065 spx_word32_t *g0_mem, *g1_mem;
00067 spx_sig_t *excBuf;
00068 spx_sig_t *exc;
00069 spx_sig_t *buf;
00070 spx_sig_t *res;
00071 spx_sig_t *sw;
00072 spx_sig_t *target;
00073 spx_word16_t *window;
00074 spx_word16_t *lagWindow;
00075 spx_word16_t *autocorr;
00076 spx_coef_t *lpc;
00077 spx_lsp_t *lsp;
00078 spx_lsp_t *qlsp;
00079 spx_lsp_t *old_lsp;
00080 spx_lsp_t *old_qlsp;
00081 spx_lsp_t *interp_lsp;
00082 spx_lsp_t *interp_qlsp;
00083 spx_coef_t *interp_lpc;
00084 spx_coef_t *interp_qlpc;
00085 spx_coef_t *bw_lpc1;
00086 spx_coef_t *bw_lpc2;
00088 spx_mem_t *mem_sp;
00089 spx_mem_t *mem_sp2;
00090 spx_mem_t *mem_sw;
00091 spx_word32_t *pi_gain;
00092
00093 float vbr_quality;
00094 int vbr_enabled;
00095 int abr_enabled;
00096 float abr_drift;
00097 float abr_drift2;
00098 float abr_count;
00099 int vad_enabled;
00100 float relative_quality;
00101
00102 int encode_submode;
00103 const SpeexSubmode * const *submodes;
00104 int submodeID;
00105 int submodeSelect;
00106 int complexity;
00107 int sampling_rate;
00108
00109 } SBEncState;
00110
00111
00113 typedef struct SBDecState {
00114 const SpeexMode *mode;
00115 void *st_low;
00116 int full_frame_size;
00117 int frame_size;
00118 int subframeSize;
00119 int nbSubframes;
00120 int lpcSize;
00121 int first;
00122 int sampling_rate;
00123 int lpc_enh_enabled;
00124
00125 char *stack;
00126 spx_sig_t *x0d, *x1d;
00127 spx_sig_t *high;
00128 spx_sig_t *y0, *y1;
00129 spx_word32_t *g0_mem, *g1_mem;
00130
00131 spx_sig_t *exc;
00132 spx_lsp_t *qlsp;
00133 spx_lsp_t *old_qlsp;
00134 spx_lsp_t *interp_qlsp;
00135 spx_coef_t *interp_qlpc;
00136
00137 spx_mem_t *mem_sp;
00138 spx_word32_t *pi_gain;
00139
00140 int encode_submode;
00141 const SpeexSubmode * const *submodes;
00142 int submodeID;
00143 } SBDecState;
00144
00145
00147 void *sb_encoder_init(const SpeexMode *m);
00148
00150 void sb_encoder_destroy(void *state);
00151
00153 int sb_encode(void *state, void *in, SpeexBits *bits);
00154
00155
00157 void *sb_decoder_init(const SpeexMode *m);
00158
00160 void sb_decoder_destroy(void *state);
00161
00163 int sb_decode(void *state, SpeexBits *bits, void *out);
00164
00165 int sb_encoder_ctl(void *state, int request, void *ptr);
00166
00167 int sb_decoder_ctl(void *state, int request, void *ptr);
00168
00169 #endif