tns.h
上传用户:sun1608
上传日期:2007-02-02
资源大小:6116k
文件大小:2k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

Visual C++

  1. /*
  2.  * FAAC - Freeware Advanced Audio Coder
  3.  * Copyright (C) 2001 Menno Bakker
  4.  *
  5.  * This library is free software; you can redistribute it and/or
  6.  * modify it under the terms of the GNU Lesser General Public
  7.  * License as published by the Free Software Foundation; either
  8.  * version 2.1 of the License, or (at your option) any later version.
  9.  *
  10.  * This library is distributed in the hope that it will be useful,
  11.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  13.  * Lesser General Public License for more details.
  14.  * You should have received a copy of the GNU Lesser General Public
  15.  * License along with this library; if not, write to the Free Software
  16.  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  17.  *
  18.  * $Id: tns.h,v 1.5 2001/06/04 23:02:24 wmay Exp $
  19.  */
  20. #ifndef TNS_H
  21. #define TNS_H
  22. #ifdef __cplusplus
  23. extern "C" {
  24. #endif /* __cplusplus */
  25. /*************************/
  26. /* Function prototypes   */
  27. /*************************/
  28. static void Autocorrelation(int maxOrder,        /* Maximum autocorr order */
  29.  int dataSize,   /* Size of the data array */
  30.  double* data,   /* Data array */
  31.  double* rArray);   /* Autocorrelation array */
  32. static double LevinsonDurbin(int maxOrder,        /* Maximum filter order */
  33.   int dataSize,    /* Size of the data array */
  34.   double* data,    /* Data array */
  35.   double* kArray);    /* Reflection coeff array */
  36. static void StepUp(int fOrder, double* kArray, double* aArray);
  37. static void QuantizeReflectionCoeffs(int fOrder,int coeffRes,double* rArray,int* indexArray);
  38. static int TruncateCoeffs(int fOrder,double threshold,double* kArray);
  39. static void TnsFilter(int length,double* spec,TnsFilterData* filter);
  40. static void TnsInvFilter(int length,double* spec,TnsFilterData* filter);
  41. void TnsInit(faacEncHandle hEncoder);
  42. void TnsEncode(TnsInfo* tnsInfo, int numberOfBands,int maxSfb,enum WINDOW_TYPE blockType,
  43.    int* sfbOffsetTable,double* spec);
  44. void TnsEncodeFilterOnly(TnsInfo* tnsInfo, int numberOfBands, int maxSfb,
  45.  enum WINDOW_TYPE blockType, int *sfbOffsetTable, double *spec);
  46. void TnsDecodeFilterOnly(TnsInfo* tnsInfo, int numberOfBands, int maxSfb,
  47.  enum WINDOW_TYPE blockType, int *sfbOffsetTable, double *spec);
  48. #ifdef __cplusplus
  49. }
  50. #endif /* __cplusplus */
  51. #endif /* TNS_H */