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

流媒体/Mpeg4/MP4

开发平台:

Visual C++

  1. /*====================================================================*/
  2. /*         MPEG-4 Audio (ISO/IEC 14496-3) Copyright Header            */
  3. /*====================================================================*/
  4. /*
  5. This software module was originally developed by Rakesh Taori and Andy
  6. Gerrits (Philips Research Laboratories, Eindhoven, The Netherlands) in
  7. the course of development of the MPEG-4 Audio (ISO/IEC 14496-3). This
  8. software module is an implementation of a part of one or more MPEG-4
  9. Audio (ISO/IEC 14496-3) tools as specified by the MPEG-4 Audio
  10. (ISO/IEC 14496-3). ISO/IEC gives users of the MPEG-4 Audio (ISO/IEC
  11. 14496-3) free license to this software module or modifications thereof
  12. for use in hardware or software products claiming conformance to the
  13. MPEG-4 Audio (ISO/IEC 14496-3). Those intending to use this software
  14. module in hardware or software products are advised that its use may
  15. infringe existing patents. The original developer of this software
  16. module and his/her company, the subsequent editors and their
  17. companies, and ISO/IEC have no liability for use of this software
  18. module or modifications thereof in an implementation. Copyright is not
  19. released for non MPEG-4 Audio (ISO/IEC 14496-3) conforming products.
  20. CN1 retains full right to use the code for his/her own purpose, assign
  21. or donate the code to a third party and to inhibit third parties from
  22. using the code for non MPEG-4 Audio (ISO/IEC 14496-3) conforming
  23. products.  This copyright notice must be included in all copies or
  24. derivative works. Copyright 1996.
  25. */
  26. /*====================================================================*/
  27. /*======================================================================*/
  28. /*                                                                      */
  29. /*      INCLUDE_FILE:   PHI_LPCQ.H                                      */
  30. /*      PACKAGE:        WDBxx                                           */
  31. /*      COMPONENT:      Tables for LPC Coeffs Quantization              */
  32. /*                                                                      */
  33. /*======================================================================*/
  34. #ifndef _phi_lpcq_h_
  35. #define _phi_lpcq_h_
  36. #ifdef __cplusplus
  37. extern "C" {
  38. #endif
  39. #define SCALING_BITS_rfc     16L    /* scaling bits for rfc's           */
  40. #define SCALE_rfc     (1L << SCALING_BITS_rfc)     /* scal. of rfc's         */
  41. /*======================================================================*/
  42. /*     TABLE FOR Reflection Coefficients QUANTIZATION                   */
  43. /* UNIFORM LAR QUANTISATION ==> NONLINEAR LOOK_UP TABLE for Refl. coeffs*/
  44. /*======================================================================*/
  45. float  PHI_tbl_rfc_level[2][49] =
  46. {
  47.     {
  48.     (float)-0.9882, 
  49.     (float)-0.9848, 
  50.     (float)-0.9806, 
  51.     (float)-0.9751, 
  52.     (float)-0.9682, 
  53.     (float)-0.9593, 
  54.     (float)-0.9481, 
  55.     (float)-0.9338, 
  56.     (float)-0.9158, 
  57.     (float)-0.8932, 
  58.     (float)-0.8649, 
  59.     (float)-0.8298, 
  60.     (float)-0.7866, 
  61.     (float)-0.7341, 
  62.     (float)-0.6710, 
  63.     (float)-0.5964, 
  64.     (float)-0.5098, 
  65.     (float)-0.4116, 
  66.     (float)-0.3027, 
  67.     (float)-0.1853, 
  68.     (float)-0.0624, 
  69.     (float)0.0624, 
  70.     (float)0.1853, 
  71.     (float)0.3027, 
  72.     (float)0.4116, 
  73.     (float)0.5098, 
  74.     (float)0.5964, 
  75.     (float)0.6710, 
  76.     (float)0.7341, 
  77.     (float)0.7866, 
  78.     (float)0.8298, 
  79.     (float)0.8649, 
  80.     (float)0.8932, 
  81.     (float)0.9158, 
  82.     (float)0.9338, 
  83.     (float)0.9481, 
  84.     (float)0.9593, 
  85.     (float)0.9682, 
  86.     (float)0.9751, 
  87.     (float)0.9806, 
  88.     (float)0.9848, 
  89.     (float)0.9882, 
  90.     (float)0.9908, 
  91.     (float)0.9928, 
  92.     (float)0.9944, 
  93.     (float)0.9956, 
  94.     (float)0.9966, 
  95.     (float)0.9973, 
  96.     (float)0.9999
  97.      },
  98.      
  99.      {
  100.     (long) (-0.9896 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  101.     (long) (-0.9866 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  102.     (long) (-0.9828 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  103.     (long) (-0.9780 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  104.     (long) (-0.9719 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  105.     (long) (-0.9640 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  106.     (long) (-0.9540 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  107.     (long) (-0.9414 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  108.     (long) (-0.9253 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  109.     (long) (-0.9051 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  110.     (long) (-0.8798 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  111.     (long) (-0.8483 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  112.     (long) (-0.8093 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  113.     (long) (-0.7616 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  114.     (long) (-0.7039 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  115.     (long) (-0.6351 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  116.     (long) (-0.5546 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  117.     (long) (-0.4621 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  118.     (long) (-0.3584 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  119.     (long) (-0.2449 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  120.     (long) (-0.1244 * SCALE_rfc - 0.5) / (double) SCALE_rfc,
  121.     (long) (0.0000),
  122.     (long) (0.1244 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  123.     (long) (0.2449 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  124.     (long) (0.3584 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  125.     (long) (0.4621 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  126.     (long) (0.5546 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  127.     (long) (0.6351 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  128.     (long) (0.7039 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  129.     (long) (0.7616 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  130.     (long) (0.8093 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  131.     (long) (0.8483 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  132.     (long) (0.8798 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  133.     (long) (0.9051 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  134.     (long) (0.9253 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  135.     (long) (0.9414 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  136.     (long) (0.9540 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  137.     (long) (0.9640 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  138.     (long) (0.9719 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  139.     (long) (0.9780 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  140.     (long) (0.9828 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  141.     (long) (0.9866 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  142.     (long) (0.9896 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  143.     (long) (0.9919 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  144.     (long) (0.9937 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  145.     (long) (0.9951 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  146.     (long) (0.9961 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  147.     (long) (0.9970 * SCALE_rfc + 0.5) / (double) SCALE_rfc,
  148.     (long) (0.9977 * SCALE_rfc + 0.5) / (double) SCALE_rfc
  149. }
  150. };
  151. /*======================================================================*/
  152. /*     TABLE FOR Range of reflection coeffs                             */
  153. /*======================================================================*/
  154. short PHI_tbl_rfc_range[2][20] =
  155. {
  156.     {
  157.     13,
  158.      0,
  159.     16,
  160.     12,
  161.     16,
  162.     13,
  163.     16,
  164.     14,
  165.     18,
  166.     16,
  167.     18,
  168.     17,
  169.     19,
  170.     17,
  171.     19,
  172.     18,
  173.     19,
  174.     17,
  175.     19,
  176.     18,
  177.     },
  178.     {
  179. 36,
  180. 28,
  181. 15,
  182. 14,
  183. 13,
  184. 13,
  185. 12,
  186. 11,
  187. 9,
  188. 8,
  189. 8,
  190. 7,
  191. 7,
  192. 8,
  193. 7,
  194. 6,
  195. 6,
  196. 7,
  197. 6,
  198. 6    
  199.     }
  200. };
  201. #ifdef __cplusplus
  202. }
  203. #endif
  204. #endif  /* #ifndef _phi_lpcq_h_ */
  205. /*======================================================================*/
  206. /*      H I S T O R Y                                                   */
  207. /*======================================================================*/
  208. /* 17-04-96 R. Taori  Initial Version                                   */