mpegaudiotab.h
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:3k
源码类别:

Windows CE

开发平台:

C/C++

  1. /*
  2.  * mpeg audio layer 2 tables. Most of them come from the mpeg audio
  3.  * specification.
  4.  * 
  5.  * Copyright (c) 2000, 2001 Fabrice Bellard.
  6.  *
  7.  * The licence of this code is contained in file LICENCE found in the
  8.  * same archive 
  9.  */
  10. /**
  11.  * @file mpegaudiotab.h
  12.  * mpeg audio layer 2 tables. 
  13.  * Most of them come from the mpeg audio specification.
  14.  */
  15.  
  16. #define SQRT2 1.41421356237309514547
  17. static const int costab32[30] = {
  18.     FIX(0.54119610014619701222),
  19.     FIX(1.3065629648763763537),
  20.     
  21.     FIX(0.50979557910415917998),
  22.     FIX(2.5629154477415054814),
  23.     FIX(0.89997622313641556513),
  24.     FIX(0.60134488693504528634),
  25.     
  26.     FIX(0.5024192861881556782),
  27.     FIX(5.1011486186891552563),
  28.     FIX(0.78815462345125020249),
  29.     FIX(0.64682178335999007679),
  30.     FIX(0.56694403481635768927),
  31.     FIX(1.0606776859903470633),
  32.     FIX(1.7224470982383341955),
  33.     FIX(0.52249861493968885462),
  34.     
  35.     FIX(10.19000812354803287),
  36.     FIX(0.674808341455005678),
  37.     FIX(1.1694399334328846596),
  38.     FIX(0.53104259108978413284),
  39.     FIX(2.0577810099534108446),
  40.     FIX(0.58293496820613388554),
  41.     FIX(0.83934964541552681272),
  42.     FIX(0.50547095989754364798),
  43.     FIX(3.4076084184687189804),
  44.     FIX(0.62250412303566482475),
  45.     FIX(0.97256823786196078263),
  46.     FIX(0.51544730992262455249),
  47.     FIX(1.4841646163141661852),
  48.     FIX(0.5531038960344445421),
  49.     FIX(0.74453627100229857749),
  50.     FIX(0.5006029982351962726),
  51. };
  52. static const int bitinv32[32] = {
  53.     0,  16,  8, 24,  4,  20,  12,  28,
  54.     2,  18, 10, 26,  6,  22,  14,  30,
  55.     1,  17,  9, 25,  5,  21,  13,  29,
  56.     3,  19, 11, 27,  7,  23,  15,  31
  57. };
  58. static int16_t filter_bank[512];
  59. static int scale_factor_table[64];
  60. #ifdef USE_FLOATS
  61. static float scale_factor_inv_table[64];
  62. #else
  63. static int8_t scale_factor_shift[64];
  64. static unsigned short scale_factor_mult[64];
  65. #endif
  66. static unsigned char scale_diff_table[128];
  67. /* total number of bits per allocation group */
  68. static unsigned short total_quant_bits[17];
  69. /* signal to noise ratio of each quantification step (could be
  70.    computed from quant_steps[]). The values are dB multiplied by 10 
  71. */
  72. static const unsigned short quant_snr[17] = { 
  73.      70, 110, 160, 208,
  74.     253, 316, 378, 439,
  75.     499, 559, 620, 680, 
  76.     740, 800, 861, 920, 
  77.     980
  78. };
  79. /* fixed psycho acoustic model. Values of SNR taken from the 'toolame'
  80.    project */
  81. static const float fixed_smr[SBLIMIT] =  {
  82.     30, 17, 16, 10, 3, 12, 8, 2.5,
  83.     5, 5, 6, 6, 5, 6, 10, 6,
  84.     -4, -10, -21, -30, -42, -55, -68, -75,
  85.     -75, -75, -75, -75, -91, -107, -110, -108
  86. };
  87. static const unsigned char nb_scale_factors[4] = { 3, 2, 1, 2 };