# HG changeset patch # User vitor # Date 1257768379 0 # Node ID f132cde57bbedf751a03d068be5dcf7cbefb711e # Parent bdf4a9ca162a2d2b1697a1eb7679672cdf4c867b Do not hardcode filter order in ff_acelp_lspd2lpc() diff -r bdf4a9ca162a -r f132cde57bbe lsp.c --- a/lsp.c Mon Nov 09 09:11:35 2009 +0000 +++ b/lsp.c Mon Nov 09 12:06:19 2009 +0000 @@ -155,20 +155,19 @@ } } -void ff_acelp_lspd2lpc(const double *lsp, float *lpc) +void ff_acelp_lspd2lpc(const double *lsp, float *lpc, int lp_half_order) { - double pa[6], qa[6]; - int i; - - lsp2polyf(lsp, pa, 5); - lsp2polyf(lsp + 1, qa, 5); + double pa[lp_half_order+1], qa[lp_half_order+1]; + float *lpc2 = lpc + (lp_half_order << 1) - 1; - for (i=4; i>=0; i--) - { - double paf = pa[i+1] + pa[i]; - double qaf = qa[i+1] - qa[i]; + lsp2polyf(lsp, pa, lp_half_order); + lsp2polyf(lsp + 1, qa, lp_half_order); - lpc[i ] = 0.5*(paf+qaf); - lpc[9-i] = 0.5*(paf-qaf); + while (lp_half_order--) { + double paf = pa[lp_half_order+1] + pa[lp_half_order]; + double qaf = qa[lp_half_order+1] - qa[lp_half_order]; + + lpc [ lp_half_order] = 0.5*(paf+qaf); + lpc2[-lp_half_order] = 0.5*(paf-qaf); } } diff -r bdf4a9ca162a -r f132cde57bbe lsp.h --- a/lsp.h Mon Nov 09 09:11:35 2009 +0000 +++ b/lsp.h Mon Nov 09 12:06:19 2009 +0000 @@ -86,8 +86,10 @@ * @param lsp line spectral pairs in cosine domain * @param lpc linear predictive coding coefficients * + * @note buffers should have a minimux size of 2*lp_half_order elements. + * * TIA/EIA/IS-733 2.4.3.3.5 */ -void ff_acelp_lspd2lpc(const double *lsp, float *lpc); +void ff_acelp_lspd2lpc(const double *lsp, float *lpc, int lp_half_order); #endif /* AVCODEC_LSP_H */ diff -r bdf4a9ca162a -r f132cde57bbe qcelpdec.c --- a/qcelpdec.c Mon Nov 09 09:11:35 2009 +0000 +++ b/qcelpdec.c Mon Nov 09 12:06:19 2009 +0000 @@ -578,7 +578,7 @@ for (i=0; i<10; i++) lsp[i] = cos(M_PI * lspf[i]); - ff_acelp_lspd2lpc(lsp, lpc); + ff_acelp_lspd2lpc(lsp, lpc, 5); for (i=0; i<10; i++) {