00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef AVCODEC_LSP_H
00024 #define AVCODEC_LSP_H
00025
00026 #include <stdint.h>
00027
00040 void ff_acelp_reorder_lsf(int16_t* lsfq, int lsfq_min_distance, int lsfq_min, int lsfq_max, int lp_order);
00041
00053 void ff_set_min_dist_lsf(float *lsf, double min_spacing, int size);
00054
00063 void ff_acelp_lsf2lsp(int16_t *lsp, const int16_t *lsf, int lp_order);
00064
00068 void ff_acelp_lsf2lspd(double *lsp, const float *lsf, int lp_order);
00069
00076 void ff_acelp_lsp2lpc(int16_t* lp, const int16_t* lsp, int lp_half_order);
00077
00081 void ff_amrwb_lsp2lpc(const double *lsp, float *lp, int lp_order);
00082
00091 void ff_acelp_lp_decode(int16_t* lp_1st, int16_t* lp_2nd, const int16_t* lsp_2nd, const int16_t* lsp_prev, int lp_order);
00092
00093
00094 #define MAX_LP_HALF_ORDER 10
00095 #define MAX_LP_ORDER (2*MAX_LP_HALF_ORDER)
00096
00109 void ff_acelp_lspd2lpc(const double *lsp, float *lpc, int lp_half_order);
00110
00116 void ff_sort_nearly_sorted_floats(float *vals, int len);
00117
00128 void ff_lsp2polyf(const double *lsp, double *f, int lp_half_order);
00129
00130 #endif