亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? layer3.c

?? symbian下mp3文件的解碼源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* * NAME:	III_sideinfo() * DESCRIPTION:	decode frame side information from a bitstream */staticenum mad_error III_sideinfo(struct mad_bitptr *ptr, unsigned int nch,			    int lsf, struct sideinfo *si,			    unsigned int *data_bitlen,			    unsigned int *priv_bitlen){  unsigned int ngr, gr, ch, i;  enum mad_error result = MAD_ERROR_NONE;  *data_bitlen = 0;  *priv_bitlen = lsf ? ((nch == 1) ? 1 : 2) : ((nch == 1) ? 5 : 3);  si->main_data_begin = mad_bit_read(ptr, lsf ? 8 : 9);  si->private_bits    = mad_bit_read(ptr, *priv_bitlen);  ngr = 1;  if (!lsf) {    ngr = 2;    for (ch = 0; ch < nch; ++ch)      si->scfsi[ch] = mad_bit_read(ptr, 4);  }  for (gr = 0; gr < ngr; ++gr) {    struct granule *granule = &si->gr[gr];    for (ch = 0; ch < nch; ++ch) {      struct channel *channel = &granule->ch[ch];      channel->part2_3_length    = mad_bit_read(ptr, 12);      channel->big_values        = mad_bit_read(ptr, 9);      channel->global_gain       = mad_bit_read(ptr, 8);      channel->scalefac_compress = mad_bit_read(ptr, lsf ? 9 : 4);      *data_bitlen += channel->part2_3_length;      if (channel->big_values > 288 && result == 0)	result = MAD_ERROR_BADBIGVALUES;      channel->flags = 0;      /* window_switching_flag */      if (mad_bit_read(ptr, 1)) {	channel->block_type = mad_bit_read(ptr, 2);	if (channel->block_type == 0 && result == 0)	  result = MAD_ERROR_BADBLOCKTYPE;	if (!lsf && channel->block_type == 2 && si->scfsi[ch] && result == 0)	  result = MAD_ERROR_BADSCFSI;	channel->region0_count = 7;	channel->region1_count = 36;	if (mad_bit_read(ptr, 1))	  channel->flags |= mixed_block_flag;	else if (channel->block_type == 2)	  channel->region0_count = 8;	for (i = 0; i < 2; ++i)	  channel->table_select[i] = mad_bit_read(ptr, 5);# if defined(DEBUG)	channel->table_select[2] = 4;  /* not used */# endif	for (i = 0; i < 3; ++i)	  channel->subblock_gain[i] = mad_bit_read(ptr, 3);      }      else {	channel->block_type = 0;	for (i = 0; i < 3; ++i)	  channel->table_select[i] = mad_bit_read(ptr, 5);	channel->region0_count = mad_bit_read(ptr, 4);	channel->region1_count = mad_bit_read(ptr, 3);      }      /* [preflag,] scalefac_scale, count1table_select */      channel->flags |= mad_bit_read(ptr, lsf ? 2 : 3);    }  }  return result;}/* * NAME:	III_scalefactors_lsf() * DESCRIPTION:	decode channel scalefactors for LSF from a bitstream */staticunsigned int III_scalefactors_lsf(struct mad_bitptr *ptr,				  struct channel *channel,				  struct channel *gr1ch, int mode_extension){  struct mad_bitptr start;  unsigned int scalefac_compress, index, slen[4], part, n, i;  unsigned char const *nsfb;  start = *ptr;  scalefac_compress = channel->scalefac_compress;  index = (channel->block_type == 2) ?    ((channel->flags & mixed_block_flag) ? 2 : 1) : 0;  if (!((mode_extension & I_STEREO) && gr1ch)) {    if (scalefac_compress < 400) {      slen[0] = (scalefac_compress >> 4) / 5;      slen[1] = (scalefac_compress >> 4) % 5;      slen[2] = (scalefac_compress % 16) >> 2;      slen[3] =  scalefac_compress %  4;      nsfb = nsfb_table[0][index];    }    else if (scalefac_compress < 500) {      scalefac_compress -= 400;      slen[0] = (scalefac_compress >> 2) / 5;      slen[1] = (scalefac_compress >> 2) % 5;      slen[2] =  scalefac_compress %  4;      slen[3] = 0;      nsfb = nsfb_table[1][index];    }    else {      scalefac_compress -= 500;      slen[0] = scalefac_compress / 3;      slen[1] = scalefac_compress % 3;      slen[2] = 0;      slen[3] = 0;      channel->flags |= preflag;      nsfb = nsfb_table[2][index];    }    n = 0;    for (part = 0; part < 4; ++part) {      for (i = 0; i < nsfb[part]; ++i)	channel->scalefac[n++] = mad_bit_read(ptr, slen[part]);    }    while (n < 39)      channel->scalefac[n++] = 0;  }  else {  /* (mode_extension & I_STEREO) && gr1ch (i.e. ch == 1) */    scalefac_compress >>= 1;    if (scalefac_compress < 180) {      slen[0] =  scalefac_compress / 36;      slen[1] = (scalefac_compress % 36) / 6;      slen[2] = (scalefac_compress % 36) % 6;      slen[3] = 0;      nsfb = nsfb_table[3][index];    }    else if (scalefac_compress < 244) {      scalefac_compress -= 180;      slen[0] = (scalefac_compress % 64) >> 4;      slen[1] = (scalefac_compress % 16) >> 2;      slen[2] =  scalefac_compress %  4;      slen[3] = 0;      nsfb = nsfb_table[4][index];    }    else {      scalefac_compress -= 244;      slen[0] = scalefac_compress / 3;      slen[1] = scalefac_compress % 3;      slen[2] = 0;      slen[3] = 0;      nsfb = nsfb_table[5][index];    }    n = 0;    for (part = 0; part < 4; ++part) {      unsigned int max, is_pos;      max = (1 << slen[part]) - 1;      for (i = 0; i < nsfb[part]; ++i) {	is_pos = mad_bit_read(ptr, slen[part]);	channel->scalefac[n] = is_pos;	gr1ch->scalefac[n++] = (is_pos == max);      }    }    while (n < 39) {      channel->scalefac[n] = 0;      gr1ch->scalefac[n++] = 0;  /* apparently not illegal */    }  }  return mad_bit_length(&start, ptr);}/* * NAME:	III_scalefactors() * DESCRIPTION:	decode channel scalefactors of one granule from a bitstream */staticunsigned int III_scalefactors(struct mad_bitptr *ptr, struct channel *channel,			      struct channel const *gr0ch, unsigned int scfsi){  struct mad_bitptr start;  unsigned int slen1, slen2, sfbi;  start = *ptr;  slen1 = sflen_table[channel->scalefac_compress].slen1;  slen2 = sflen_table[channel->scalefac_compress].slen2;  if (channel->block_type == 2) {    unsigned int nsfb;    sfbi = 0;    nsfb = (channel->flags & mixed_block_flag) ? 8 + 3 * 3 : 6 * 3;    while (nsfb--)      channel->scalefac[sfbi++] = mad_bit_read(ptr, slen1);    nsfb = 6 * 3;    while (nsfb--)      channel->scalefac[sfbi++] = mad_bit_read(ptr, slen2);    nsfb = 1 * 3;    while (nsfb--)      channel->scalefac[sfbi++] = 0;  }  else {  /* channel->block_type != 2 */    if (scfsi & 0x8) {      for (sfbi = 0; sfbi < 6; ++sfbi)	channel->scalefac[sfbi] = gr0ch->scalefac[sfbi];    }    else {      for (sfbi = 0; sfbi < 6; ++sfbi)	channel->scalefac[sfbi] = mad_bit_read(ptr, slen1);    }    if (scfsi & 0x4) {      for (sfbi = 6; sfbi < 11; ++sfbi)	channel->scalefac[sfbi] = gr0ch->scalefac[sfbi];    }    else {      for (sfbi = 6; sfbi < 11; ++sfbi)	channel->scalefac[sfbi] = mad_bit_read(ptr, slen1);    }    if (scfsi & 0x2) {      for (sfbi = 11; sfbi < 16; ++sfbi)	channel->scalefac[sfbi] = gr0ch->scalefac[sfbi];    }    else {      for (sfbi = 11; sfbi < 16; ++sfbi)	channel->scalefac[sfbi] = mad_bit_read(ptr, slen2);    }    if (scfsi & 0x1) {      for (sfbi = 16; sfbi < 21; ++sfbi)	channel->scalefac[sfbi] = gr0ch->scalefac[sfbi];    }    else {      for (sfbi = 16; sfbi < 21; ++sfbi)	channel->scalefac[sfbi] = mad_bit_read(ptr, slen2);    }    channel->scalefac[21] = 0;  }  return mad_bit_length(&start, ptr);}/* * The Layer III formula for requantization and scaling is defined by * section 2.4.3.4.7.1 of ISO/IEC 11172-3, as follows: * *   long blocks: *   xr[i] = sign(is[i]) * abs(is[i])^(4/3) * *           2^((1/4) * (global_gain - 210)) * *           2^-(scalefac_multiplier * *               (scalefac_l[sfb] + preflag * pretab[sfb])) * *   short blocks: *   xr[i] = sign(is[i]) * abs(is[i])^(4/3) * *           2^((1/4) * (global_gain - 210 - 8 * subblock_gain[w])) * *           2^-(scalefac_multiplier * scalefac_s[sfb][w]) * *   where: *   scalefac_multiplier = (scalefac_scale + 1) / 2 * * The routines III_exponents() and III_requantize() facilitate this * calculation. *//* * NAME:	III_exponents() * DESCRIPTION:	calculate scalefactor exponents */staticvoid III_exponents(struct channel const *channel,		   unsigned char const *sfbwidth, signed int exponents[39]){  signed int gain;  unsigned int scalefac_multiplier, sfbi;  gain = (signed int) channel->global_gain - 210;  scalefac_multiplier = (channel->flags & scalefac_scale) ? 2 : 1;  if (channel->block_type == 2) {    unsigned int l;    signed int gain0, gain1, gain2;    sfbi = l = 0;    if (channel->flags & mixed_block_flag) {      unsigned int premask;      premask = (channel->flags & preflag) ? ~0 : 0;      /* long block subbands 0-1 */      while (l < 36) {	exponents[sfbi] = gain -	  (signed int) ((channel->scalefac[sfbi] + (pretab[sfbi] & premask)) <<			scalefac_multiplier);	l += sfbwidth[sfbi++];      }    }    /* this is probably wrong for 8000 Hz short/mixed blocks */    gain0 = gain - 8 * (signed int) channel->subblock_gain[0];    gain1 = gain - 8 * (signed int) channel->subblock_gain[1];    gain2 = gain - 8 * (signed int) channel->subblock_gain[2];    while (l < 576) {      exponents[sfbi + 0] = gain0 -	(signed int) (channel->scalefac[sfbi + 0] << scalefac_multiplier);      exponents[sfbi + 1] = gain1 -	(signed int) (channel->scalefac[sfbi + 1] << scalefac_multiplier);      exponents[sfbi + 2] = gain2 -	(signed int) (channel->scalefac[sfbi + 2] << scalefac_multiplier);      l    += 3 * sfbwidth[sfbi];      sfbi += 3;    }  }  else {  /* channel->block_type != 2 */    if (channel->flags & preflag) {      for (sfbi = 0; sfbi < 22; ++sfbi) {	exponents[sfbi] = gain -	  (signed int) ((channel->scalefac[sfbi] + pretab[sfbi]) <<			scalefac_multiplier);      }    }    else {      for (sfbi = 0; sfbi < 22; ++sfbi) {	exponents[sfbi] = gain -	  (signed int) (channel->scalefac[sfbi] << scalefac_multiplier);      }    }  }}/* * NAME:	III_requantize() * DESCRIPTION:	requantize one (positive) value */staticmad_fixed_t III_requantize(unsigned int value, signed int exp){  mad_fixed_t requantized;  signed int frac;  struct fixedfloat const *power;  frac = exp % 4;  /* assumes sign(frac) == sign(exp) */  exp /= 4;  power = &rq_table[value];  requantized = power->mantissa;  exp += power->exponent;  if (exp < 0) {    if (-exp >= sizeof(mad_fixed_t) * CHAR_BIT) {      /* underflow */      requantized = 0;    }    else {      requantized += 1L << (-exp - 1);      requantized >>= -exp;    }  }  else {    if (exp >= 5) {      /* overflow */# if defined(DEBUG)      fprintf(stderr, "requantize overflow (%f * 2^%d)\n",	      mad_f_todouble(requantized), exp);# endif      requantized = MAD_F_MAX;    }    else      requantized <<= exp;  }  return frac ? mad_f_mul(requantized, root_table[3 + frac]) : requantized;}/* we must take care that sz >= bits and sz < sizeof(long) lest bits == 0 */# define MASK(cache, sz, bits)	\    (((cache) >> ((sz) - (bits))) & ((1 << (bits)) - 1))# define MASK1BIT(cache, sz)  \    ((cache) & (1 << ((sz) - 1)))/* * NAME:	III_huffdecode() * DESCRIPTION:	decode Huffman code words of one channel of one granule */staticenum mad_error III_huffdecode(struct mad_bitptr *ptr, mad_fixed_t xr[576],			      struct channel *channel,			      unsigned char const *sfbwidth,			      unsigned int part2_length){  signed int exponents[39], exp;  signed int const *expptr;  struct mad_bitptr peek;  signed int bits_left, cachesz;  register mad_fixed_t *xrptr;  mad_fixed_t const *sfbound;  register unsigned long bitcache;  bits_left = (signed) channel->part2_3_length - (signed) part2_length;  if (bits_left < 0)    return MAD_ERROR_BADPART3LEN;  III_exponents(channel, sfbwidth, exponents);  peek = *ptr;  mad_bit_skip(ptr, bits_left);  /* align bit reads to byte boundaries */  cachesz  = mad_bit_bitsleft(&peek);  cachesz += ((32 - 1 - 24) + (24 - cachesz)) & ~7;  bitcache   = mad_bit_read(&peek, cachesz);  bits_left -= cachesz;  xrptr = &xr[0];  /* big_values */  {    unsigned int region, rcount;    struct hufftable const *entry;    union huffpair const *table;    unsigned int linbits, startbits, big_values, reqhits;    mad_fixed_t reqcache[16];    sfbound = xrptr + *sfbwidth++;    rcount  = channel->region0_count + 1;    entry     = &mad_huff_pair_table[channel->table_select[region = 0]];    table     = entry->table;    linbits   = entry->linbits;    startbits = entry->startbits;    if (table == 0)      return MAD_ERROR_BADHUFFTABLE;    expptr  = &exponents[0];    exp     = *expptr++;    reqhits = 0;    big_values = channel->big_values;    while (big_values-- && cachesz + bits_left > 0) {      union huffpair const *pair;      unsigned int clumpsz, value;      register mad_fixed_t requantized;      if (xrptr == sfbound) {	sfbound += *sfbwidth++;	/* change table if region boundary */	if (--rcount == 0) {	  if (region == 0)	    rcount = channel->region1_count + 1;	  else	    rcount = 0;  /* all remaining */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久99久久精品国产片果冻 | 成人午夜在线免费| 久久精品亚洲乱码伦伦中文| 国产一区二区精品久久99| 久久久精品免费观看| 丁香六月综合激情| 一区二区三区四区激情| 91麻豆精品国产91| 国内一区二区视频| 亚洲婷婷综合色高清在线| 欧美日韩一二三| 国内精品嫩模私拍在线| 亚洲欧美在线观看| 欧美综合欧美视频| 久久se精品一区二区| 国产精品久久一级| 欧美久久久久久久久久| 国产综合色在线视频区| 综合激情网...| 91精品国产综合久久精品麻豆| 久久99精品国产91久久来源| 中文字幕亚洲综合久久菠萝蜜| 欧美日韩免费在线视频| 国产一区二区电影| 亚洲自拍偷拍图区| 久久天堂av综合合色蜜桃网| 在线日韩av片| 国产乱码精品一品二品| 亚洲激情成人在线| 精品久久久久av影院| 91女神在线视频| 激情六月婷婷久久| 亚洲一区自拍偷拍| 日本一区二区三区国色天香| 欧美日韩国产一级| 不卡的看片网站| 精品一区二区影视| 亚洲在线视频网站| 欧美激情资源网| 91精品久久久久久久久99蜜臂| 成人综合在线观看| 日本成人中文字幕| 夜夜亚洲天天久久| 国产精品三级av| 日韩欧美国产1| 欧美日韩一本到| 一本高清dvd不卡在线观看| 国产一区视频网站| 免费的成人av| 亚洲国产aⅴ成人精品无吗| 亚洲欧洲国产日本综合| 久久久九九九九| 精品少妇一区二区三区日产乱码 | 激情欧美一区二区三区在线观看| 亚洲一区二区3| 亚洲同性同志一二三专区| 久久免费视频色| 91精品国产综合久久精品| 欧美三电影在线| 在线一区二区三区| 91啦中文在线观看| www.亚洲在线| 成人免费毛片片v| 国产成人8x视频一区二区| 经典三级视频一区| 久久精品久久99精品久久| 美女网站一区二区| 蜜臀av一区二区在线观看 | 国产亚洲美州欧州综合国| 精品少妇一区二区| 精品国产不卡一区二区三区| 日韩欧美视频在线 | 久久久精品影视| 久久久久久影视| 久久久久国产精品麻豆ai换脸 | 亚洲黄色在线视频| 亚洲欧美日韩在线播放| 亚洲精品高清在线观看| 亚洲黄色av一区| 亚洲精品一二三区| 亚洲国产日韩a在线播放性色| 亚洲永久免费视频| 偷拍与自拍一区| 欧美a级一区二区| 极品尤物av久久免费看| 国产尤物一区二区在线| 成人av在线资源| 91蜜桃在线观看| 欧美在线观看你懂的| 制服丝袜亚洲色图| 欧美电影免费观看完整版 | 亚洲欧美日韩国产成人精品影院| 日韩理论片一区二区| 亚洲444eee在线观看| 久久99久久久久久久久久久| 国产成人av影院| 色偷偷成人一区二区三区91| 欧美日本一区二区| 亚洲精品一区二区三区99 | 亚洲一区在线观看免费观看电影高清| 首页欧美精品中文字幕| 国产毛片精品视频| 91婷婷韩国欧美一区二区| 欧美日韩成人高清| 精品黑人一区二区三区久久 | 成人免费视频caoporn| 91成人国产精品| 欧美成人三级电影在线| 中文字幕一区二区视频| 亚洲va国产va欧美va观看| 国产二区国产一区在线观看| 日本高清无吗v一区| 日韩三级.com| 自拍偷在线精品自拍偷无码专区 | 亚洲一区中文日韩| 国产一区在线观看视频| 91国产丝袜在线播放| 久久影院午夜片一区| 一区二区三区免费观看| 黑人巨大精品欧美一区| 91免费国产在线| 国产亚洲一区字幕| 亚洲国产美女搞黄色| 国产高清亚洲一区| 欧美二区三区91| 成人欧美一区二区三区1314| 美女久久久精品| 在线观看日产精品| 亚洲国产精品t66y| 日本不卡一区二区三区| 91麻豆成人久久精品二区三区| 日韩欧美精品在线视频| 亚洲免费伊人电影| 国产传媒一区在线| 日韩午夜在线观看| 一二三四社区欧美黄| aaa亚洲精品| 久久九九99视频| 蜜桃传媒麻豆第一区在线观看| 91久久线看在观草草青青| 久久精品亚洲精品国产欧美| 免费人成黄页网站在线一区二区| 91老师片黄在线观看| 国产欧美一区二区三区在线老狼| 成人免费视频视频| 日韩区在线观看| 日韩av在线发布| 欧美午夜影院一区| 亚洲欧美国产77777| 顶级嫩模精品视频在线看| 久久婷婷久久一区二区三区| 久久精品理论片| 欧美成人r级一区二区三区| 日韩电影在线看| 4438x成人网最大色成网站| 亚洲国产一区二区三区| 在线免费观看一区| 亚洲乱码中文字幕综合| 91丨九色丨蝌蚪丨老版| 国产精品国产三级国产aⅴ入口 | 亚洲欧美另类在线| 91蝌蚪porny| 亚洲黄网站在线观看| 欧美视频一区二区三区四区 | 国产精品一区在线观看你懂的| 精品理论电影在线观看| 久久精品国产久精国产| 欧美成人欧美edvon| 狠狠色丁香久久婷婷综合_中 | 精品影院一区二区久久久| 日韩精品一区国产麻豆| 蜜桃精品视频在线| 久久午夜电影网| av电影在线观看一区| 亚洲人午夜精品天堂一二香蕉| 99r国产精品| 一区二区三区四区亚洲| 欧美中文字幕一二三区视频| 亚洲成av人片在线观看| 日韩精品自拍偷拍| 风间由美一区二区av101| 《视频一区视频二区| 欧美在线视频日韩| 日本伊人色综合网| 精品国产乱码久久久久久久久| 亚洲美女在线国产| 成人一道本在线| 日韩码欧中文字| 91 com成人网| 精品一区二区三区在线观看国产 | 精品一区二区综合| 国产精品免费视频一区| 91福利在线免费观看| 免费黄网站欧美| 久久精品人人做人人爽人人| 色综合久久88色综合天天6| 日韩极品在线观看| 欧美国产日韩a欧美在线观看| 在线影院国内精品| 久久爱另类一区二区小说|