123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
-
-
- #include "lsp_avg.h"
- const char lsp_avg_id[] = "@(#)$Id $" lsp_avg_h;
-
- #include <stdlib.h>
- #include <stdio.h>
- #include "basic_op.h"
- #include "oper_32b.h"
- #include "count.h"
- #include "q_plsf_5.tab"
- #include "copy.h"
- int lsp_avg_init (lsp_avgState **state)
- {
- lsp_avgState* s;
-
- if (state == (lsp_avgState **) NULL){
- wfprintf(stderr, "lsp_avg_init: invalid parameter\n");
- return -1;
- }
- *state = NULL;
-
-
- if ((s = (lsp_avgState *) wmalloc(sizeof(lsp_avgState))) == NULL){
- wfprintf(stderr, "lsp_avg_init: can not malloc state structure\n");
- return -1;
- }
- lsp_avg_reset(s);
- *state = s;
-
- return 0;
- }
-
- int lsp_avg_reset (lsp_avgState *st)
- {
- if (st == (lsp_avgState *) NULL){
- wfprintf(stderr, "lsp_avg_reset: invalid parameter\n");
- return -1;
- }
- Copy(mean_lsf, &st->lsp_meanSave[0], M);
-
- return 0;
- }
-
- void lsp_avg_exit (lsp_avgState **state)
- {
- if (state == NULL || *state == NULL)
- return;
-
- wfree(*state);
- *state = NULL;
-
- return;
- }
- void lsp_avg (
- lsp_avgState *st,
- Word16 *lsp
- )
- {
- Word16 i;
- Word32 L_tmp;
- for (i = 0; i < M; i++) {
-
- L_tmp = L_deposit_h_ex(st->lsp_meanSave[i]);
- L_tmp = L_msu_ex(L_tmp, EXPCONST, st->lsp_meanSave[i]);
-
- L_tmp = L_mac_ex(L_tmp, EXPCONST, lsp[i]);
-
- st->lsp_meanSave[i] = round_ex(L_tmp); move16();
- }
- return;
- }
|