123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- /*
- ********************************************************************************
- *
- * 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 : int_lsf.c
- *
- ********************************************************************************
- */
- /*
- ********************************************************************************
- * MODULE INCLUDE FILE AND VERSION ID
- ********************************************************************************
- */
- #include "int_lsf.h"
- const char int_lsf_id[] = "@(#)$Id $" int_lsf_h;
-
- /*
- ********************************************************************************
- * INCLUDE FILES
- ********************************************************************************
- */
- #include "typedef.h"
- #include "basic_op.h"
- #include "count.h"
- #include "cnst.h"
- /*
- ********************************************************************************
- * LOCAL VARIABLES AND TABLES
- ********************************************************************************
- */
- /*
- *--------------------------------------*
- * Constants (defined in cnst.h) *
- *--------------------------------------*
- * M : LSF order *
- *--------------------------------------*
- */
-
- /*
- ********************************************************************************
- * PUBLIC PROGRAM CODE
- ********************************************************************************
- */
- /*
- **************************************************************************
- *
- * Function : Int_lsf
- * Purpose : Interpolates the LSFs for selected subframe
- * Description : The 20 ms speech frame is divided into 4 subframes.
- * The LSFs are interpolated at the 1st, 2nd and 3rd
- * subframe and only forwarded at the 4th subframe.
- *
- * |------|------|------|------|
- * sf1 sf2 sf3 sf4
- * F0 F1
- *
- * sf1: 3/4 F0 + 1/4 F1 sf3: 1/4 F0 + 3/4 F1
- * sf2: 1/2 F0 + 1/2 F1 sf4: F1
- * Returns : void
- *
- **************************************************************************
- */
- void Int_lsf(
- Word16 lsf_old[], /* i : LSF vector at the 4th SF of past frame */
- Word16 lsf_new[], /* i : LSF vector at the 4th SF of present frame */
- Word16 i_subfr, /* i : Pointer to current sf (equal to 0,40,80 or 120) */
- Word16 lsf_out[] /* o : interpolated LSF parameters for current sf */
- )
- {
- Word16 i;
- if ( i_subfr == 0 )
- {
- test ();
- for (i = 0; i < M; i++) {
- lsf_out[i] = add_ex(sub_ex(lsf_old[i], shr_ex(lsf_old[i], 2)), shr_ex(lsf_new[i], 2));
- move16 ();
- }
- }
- else if ( sub_ex(i_subfr, 40) == 0 )
- {
- test (); test ();
- for (i = 0; i < M; i++) {
- lsf_out[i] = add_ex(shr_ex(lsf_old[i],1), shr_ex(lsf_new[i], 1) );
- move16 ();
- }
- }
- else if ( sub_ex(i_subfr, 80) == 0 )
- {
- test (); test (); test ();
- for (i = 0; i < M; i++) {
- lsf_out[i] = add_ex(shr_ex(lsf_old[i], 2), sub_ex(lsf_new[i], shr_ex(lsf_new[i], 2)));
- move16 ();
- }
- }
- else if ( sub_ex(i_subfr, 120) == 0 )
- {
- test (); test (); test (); test ();
- for (i = 0; i < M; i++) {
- lsf_out[i] = lsf_new[i]; move16 ();
- }
- }
- return;
- }
|