alac: reduce the number of local variables needed in lpc prediction
This commit is contained in:
parent
01880d287b
commit
abc4376b31
@ -204,28 +204,27 @@ static void predictor_decompress_fir_adapt(int32_t *error_buffer,
|
|||||||
/* general case */
|
/* general case */
|
||||||
for (i = predictor_coef_num + 1; i < output_size; i++) {
|
for (i = predictor_coef_num + 1; i < output_size; i++) {
|
||||||
int j;
|
int j;
|
||||||
int sum = 0;
|
int val = 0;
|
||||||
int outval;
|
|
||||||
int error_val = error_buffer[i];
|
int error_val = error_buffer[i];
|
||||||
|
|
||||||
for (j = 0; j < predictor_coef_num; j++) {
|
for (j = 0; j < predictor_coef_num; j++) {
|
||||||
sum += (buffer_out[predictor_coef_num-j] - buffer_out[0]) *
|
val += (buffer_out[predictor_coef_num-j] - buffer_out[0]) *
|
||||||
predictor_coef_table[j];
|
predictor_coef_table[j];
|
||||||
}
|
}
|
||||||
|
|
||||||
outval = (1 << (predictor_quantitization-1)) + sum;
|
val = (val + (1 << (predictor_quantitization - 1))) >>
|
||||||
outval = outval >> predictor_quantitization;
|
predictor_quantitization;
|
||||||
outval = outval + buffer_out[0] + error_val;
|
val += buffer_out[0] + error_val;
|
||||||
outval = sign_extend(outval, readsamplesize);
|
|
||||||
|
|
||||||
buffer_out[predictor_coef_num+1] = outval;
|
buffer_out[predictor_coef_num + 1] = sign_extend(val, readsamplesize);
|
||||||
|
|
||||||
if (error_val > 0) {
|
if (error_val > 0) {
|
||||||
int predictor_num = predictor_coef_num - 1;
|
int predictor_num = predictor_coef_num - 1;
|
||||||
|
|
||||||
while (predictor_num >= 0 && error_val > 0) {
|
while (predictor_num >= 0 && error_val > 0) {
|
||||||
int val = buffer_out[0] - buffer_out[predictor_coef_num - predictor_num];
|
int sign;
|
||||||
int sign = sign_only(val);
|
val = buffer_out[0] - buffer_out[predictor_coef_num - predictor_num];
|
||||||
|
sign = sign_only(val);
|
||||||
|
|
||||||
predictor_coef_table[predictor_num] -= sign;
|
predictor_coef_table[predictor_num] -= sign;
|
||||||
|
|
||||||
@ -240,8 +239,9 @@ static void predictor_decompress_fir_adapt(int32_t *error_buffer,
|
|||||||
int predictor_num = predictor_coef_num - 1;
|
int predictor_num = predictor_coef_num - 1;
|
||||||
|
|
||||||
while (predictor_num >= 0 && error_val < 0) {
|
while (predictor_num >= 0 && error_val < 0) {
|
||||||
int val = buffer_out[0] - buffer_out[predictor_coef_num - predictor_num];
|
int sign;
|
||||||
int sign = - sign_only(val);
|
val = buffer_out[0] - buffer_out[predictor_coef_num - predictor_num];
|
||||||
|
sign = -sign_only(val);
|
||||||
|
|
||||||
predictor_coef_table[predictor_num] -= sign;
|
predictor_coef_table[predictor_num] -= sign;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user