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

流媒体/Mpeg4/MP4

开发平台:

Visual C++

  1. /************************************************************************
  2. This software module was originally developed by
  3. Nokia in the course of development of the MPEG-2 AAC/MPEG-4 
  4. Audio standard ISO/IEC13818-7, 14496-1, 2 and 3.
  5. This software module is an implementation of a part
  6. of one or more MPEG-2 AAC/MPEG-4 Audio tools as specified by the
  7. MPEG-2 aac/MPEG-4 Audio standard. ISO/IEC  gives users of the
  8. MPEG-2aac/MPEG-4 Audio standards free license to this software module
  9. or modifications thereof for use in hardware or software products
  10. claiming conformance to the MPEG-2 aac/MPEG-4 Audio  standards. Those
  11. intending to use this software module in hardware or software products
  12. are advised that this use may infringe existing patents. The original
  13. developer of this software module, the subsequent
  14. editors and their companies, and ISO/IEC have no liability for use of
  15. this software module or modifications thereof in an
  16. implementation. Copyright is not released for non MPEG-2 aac/MPEG-4
  17. Audio conforming products. The original developer retains full right to
  18. use the code for the developer's own purpose, assign or donate the code to a
  19. third party and to inhibit third party from using the code for non
  20. MPEG-2 aac/MPEG-4 Audio conforming products. This copyright notice
  21. must be included in all copies or derivative works.
  22. Copyright (c)1997.  
  23. ***************************************************************************/
  24. #ifndef _NOK_LT_PREDICTION_H
  25. #define _NOK_LT_PREDICTION_H
  26. #include "all.h"
  27. #include "block.h"
  28. #include "nok_ltp_common.h"
  29. #define truncate(sig_in) 
  30.          ((sig_in) > 32767 ? 32767 : ( 
  31.          (sig_in) < -32768 ? -32768 : ( 
  32.          (sig_in) > 0.0 ? (sig_in)+0.5 : ( 
  33.          (sig_in) <= 0.0 ? (sig_in)-0.5 : 0)))) 
  34. extern void nok_init_lt_pred(NOK_LT_PRED_STATUS **lt_status, int channels);
  35. extern void nok_end_lt_pred(NOK_LT_PRED_STATUS **lt_status, int channels);
  36. extern void nok_lt_predict(faacDecHandle hDecoder, Info *info, WINDOW_TYPE win_type, Wnd_Shape *win_shape,
  37.    int *sbk_prediction_used, int *sfb_prediction_used, 
  38.    NOK_LT_PRED_STATUS *lt_status, Float weight, int *delay, 
  39.    Float *current_frame, int block_size_long, int block_size_medium, 
  40.    int block_size_short, TNS_frame_info *tns_frame_info);
  41. extern void nok_lt_update(NOK_LT_PRED_STATUS *lt_status, Float *time_signal, 
  42.   Float *overlap_signal, int block_size_long);
  43. extern void nok_lt_decode(faacDecHandle hDecoder, int max_sfb, int *sbk_prediction_used, 
  44.   int *sfb_prediction_used, Float *weight, int *delay);
  45. #endif /* not defined _NOK_LT_PREDICTION_H */