123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #include "autocorr.h"
- const char autocorr_id[] = "@(#)$Id $" autocorr_h;
-
- #include "typedef.h"
- #include "basic_op.h"
- #include "oper_32b.h"
- #include "count.h"
- #include "cnst.h"
-
- Word16 Autocorr (
- Word16 x[],
- Word16 m,
- Word16 r_h[],
- Word16 r_l[],
- const Word16 wind[]
- )
- {
- Word16 i, j, norm;
- Word16 y[L_WINDOW];
- Word32 sum;
- Word16 overfl, overfl_shft;
-
- for (i = 0; i < L_WINDOW; i++)
- {
- y[i] = mult_r_ex (x[i], wind[i]); move16 ();
- }
-
- overfl_shft = 0; move16 ();
- do
- {
- overfl = 0; move16 ();
- sum = 0L; move32 ();
- for (i = 0; i < L_WINDOW; i++)
- {
- sum = L_mac_ex (sum, y[i], y[i]);
- }
-
- test ();
- if (L_sub_ex (sum, MAX_32) == 0L)
- {
- overfl_shft = add_ex (overfl_shft, 4);
- overfl = 1; move16 ();
- for (i = 0; i < L_WINDOW; i++)
- {
- y[i] = shr_ex (y[i], 2); move16 ();
- }
- }
- test ();
- }
- while (overfl != 0);
- sum = L_add_ex (sum, 1L);
-
- norm = norm_l_ex (sum);
- sum = L_shl_ex (sum, norm);
- L_Extract (sum, &r_h[0], &r_l[0]);
-
- for (i = 1; i <= m; i++)
- {
- sum = 0; move32 ();
- for (j = 0; j < L_WINDOW - i; j++)
- {
- sum = L_mac_ex (sum, y[j], y[j + i]);
- }
- sum = L_shl_ex (sum, norm);
- L_Extract (sum, &r_h[i], &r_l[i]);
- }
- norm = sub_ex (norm, overfl_shft);
- return norm;
- }
|