#ifndef NEW_PLC #define NEW_PLC #endif float _celt_lpc( celt_word16 *_lpc, /* out: [0...p-1] LPC coefficients */ const float *ac, /* in: [0...p] autocorrelation values */ int p ) { int i, j; float r; float error = ac[0]; #ifdef FIXED_POINT float lpc[LPC_ORDER]; #else float *lpc = _lpc; #endif if (ac[0] == 0) { for (i = 0; i < p; i++) lpc[i] = 0; return 0; } for (i = 0; i < p; i++) { /* Sum up this iteration's reflection coefficient */ float rr = -ac[i + 1]; for (j = 0; j < i; j++) rr = rr - lpc[j]*ac[i - j]; r = rr/(error+1e-15); /* Update LPC coefficients and total error */ lpc[i] = r; for (j = 0; j < i>>1; j++) { float tmp = lpc[j]; lpc[j] = lpc[j ] + r*lpc[i-1-j]; lpc[i-1-j] = lpc[i-1-j] + r*tmp; } if (i & 1) lpc[j] = lpc[j] + lpc[j]*r; error = error - r*r*error; if (error<.00001*ac[0]) break; } #ifdef FIXED_POINT for (i=0;i
=1;j--)
{
mem[j]=mem[j-1];
}
mem[0] = x[i];
y[i] = ROUND16(sum, SIG_SHIFT);
}
}
void iir(const celt_word32 *x,
const celt_word16 *den,
celt_word32 *y,
int N,
int ord,
celt_word16 *mem)
{
int i,j;
for (i=0;i