123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- /*
- ********************************************************************************
- *
- * GSM AMR-NB speech codec R98 Version 7.6.0 December 12, 2001
- * R99 Version 3.3.0
- * REL-4 Version 4.1.0
- *
- ********************************************************************************
- *
- * File : preemph.c
- * Purpose : Preemphasis filtering
- * Description : Filtering through 1 - g z^-1
- *
- ********************************************************************************
- */
- /*
- ********************************************************************************
- * MODULE INCLUDE FILE AND VERSION ID
- ********************************************************************************
- */
- #include "preemph.h"
- const char preemph_id[] = "@(#)$Id $" preemph_h;
- /*
- ********************************************************************************
- * INCLUDE FILES
- ********************************************************************************
- */
- #include <stdlib.h>
- #include <stdio.h>
- #include "typedef.h"
- #include "basic_op.h"
- #include "count.h"
- /*
- ********************************************************************************
- * LOCAL VARIABLES AND TABLES
- ********************************************************************************
- */
- /*
- ********************************************************************************
- * PUBLIC PROGRAM CODE
- ********************************************************************************
- */
- /*************************************************************************
- *
- * Function: Post_Filter_init
- * Purpose: Allocates memory for filter structure and initializes
- * state memory
- *
- **************************************************************************
- */
- int preemphasis_init (preemphasisState **state)
- {
- preemphasisState* s;
-
- if (state == (preemphasisState **) NULL){
- wfprintf(stderr, "preemphasis_init: invalid parameter\n");
- return -1;
- }
- *state = NULL;
-
- /* allocate memory */
- if ((s= (preemphasisState *) wmalloc(sizeof(preemphasisState))) == NULL){
- wfprintf(stderr, "preemphasis_init: can not malloc state structure\n");
- return -1;
- }
-
- preemphasis_reset(s);
- *state = s;
-
- return 0;
- }
- /*************************************************************************
- *
- * Function: preemphasis_reset
- * Purpose: Initializes state memory to zero
- *
- **************************************************************************
- */
- int preemphasis_reset (preemphasisState *state)
- {
- if (state == (preemphasisState *) NULL){
- wfprintf(stderr, "preemphasis_reset: invalid parameter\n");
- return -1;
- }
-
- state->mem_pre = 0;
-
- return 0;
- }
-
- /*************************************************************************
- *
- * Function: preemphasis_exit
- * Purpose: The memory used for state memory is freed
- *
- **************************************************************************
- */
- void preemphasis_exit (preemphasisState **state)
- {
- if (state == NULL || *state == NULL)
- return;
-
- /* deallocate memory */
- wfree(*state);
- *state = NULL;
-
- return;
- }
-
- /*
- **************************************************************************
- * Function: preemphasis
- * Purpose: Filtering through 1 - g z^-1
- *
- **************************************************************************
- */
- int preemphasis (
- preemphasisState *st, /* (i/o) : preemphasis filter state */
- Word16 *signal, /* (i/o) : input signal overwritten by the output */
- Word16 g, /* (i) : preemphasis coefficient */
- Word16 L /* (i) : size of filtering */
- )
- {
- Word16 *p1, *p2, temp, i;
- p1 = signal + L - 1; move16 ();
- p2 = p1 - 1; move16 ();
- temp = *p1; move16 ();
- for (i = 0; i <= L - 2; i++)
- {
- *p1 = sub_ex (*p1, mult_ex (g, *p2--)); move16 ();
- p1--;
- }
- *p1 = sub_ex (*p1, mult_ex (g, st->mem_pre)); move16 ();
- st->mem_pre = temp; move16 ();
- return 0;
- }
|