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

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

?? layer3.c

?? 完成MP3播放功能
?? C
?? 第 1 頁 / 共 5 頁
字號:
    MAD_F(0x00b504f3) /* 0.044194174 */,    MAD_F(0x00800000) /* 0.031250000 */,    MAD_F(0x005a827a) /* 0.022097087 */,    MAD_F(0x00400000) /* 0.015625000 */,    MAD_F(0x002d413d) /* 0.011048543 */,    MAD_F(0x00200000) /* 0.007812500 */,    MAD_F(0x0016a09e) /* 0.005524272 */  }};/* * 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++;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲毛片av在线| 午夜精品福利在线| 欧美成人性战久久| 欧美性猛交xxxx黑人交| 高清在线观看日韩| 久久国产尿小便嘘嘘尿| 日韩国产欧美三级| 香蕉成人伊视频在线观看| 综合av第一页| 日韩女优制服丝袜电影| 欧美日韩黄色一区二区| 91福利精品视频| 成人小视频免费观看| 激情欧美日韩一区二区| 精品在线播放午夜| 蓝色福利精品导航| 美女一区二区三区在线观看| 天天综合日日夜夜精品| 亚洲福利视频导航| 亚洲电影一区二区| 亚洲地区一二三色| 中文字幕视频一区二区三区久| 国产视频一区二区在线观看| 久久尤物电影视频在线观看| 久久久高清一区二区三区| 69堂精品视频| 欧美一区二区网站| 欧美videos中文字幕| 日韩欧美一级片| 欧美r级电影在线观看| 国产网红主播福利一区二区| 欧美福利视频导航| 日韩一区二区三区高清免费看看| 日韩精品专区在线影院观看| 国产视频不卡一区| 一区二区三区日韩欧美精品| 五月天激情小说综合| 亚洲高清不卡在线观看| 丝袜美腿亚洲综合| 国产精华液一区二区三区| 粉嫩绯色av一区二区在线观看| 成人av影视在线观看| 91美女片黄在线观看| 欧美伊人久久久久久久久影院| 欧美日免费三级在线| 91精品免费在线观看| 欧美成人一区二区三区片免费| 久久精品日产第一区二区三区高清版 | 欧美性极品少妇| 91精品国产综合久久久久久| 欧美va亚洲va在线观看蝴蝶网| 国产人成亚洲第一网站在线播放 | 欧美在线综合视频| 在线播放91灌醉迷j高跟美女 | 亚洲午夜久久久久| 国产一区二区三区不卡在线观看| 欧美大片日本大片免费观看| 欧美精品乱码久久久久久| 国产精品自拍一区| 国产麻豆日韩欧美久久| 国产一区在线精品| 成人短视频下载| 在线视频综合导航| 精品国偷自产国产一区| 日韩伦理免费电影| 亚洲一区在线观看视频| 亚洲美女免费视频| 国产永久精品大片wwwapp| 在线视频综合导航| 精品久久久久一区| 一区二区三区四区精品在线视频 | 久久精品免视看| 亚洲综合视频在线观看| 久久国产精品99精品国产| 成人午夜激情片| 精品国产乱码久久久久久老虎| ●精品国产综合乱码久久久久| 亚洲成人你懂的| 高清在线成人网| 91精品国产综合久久精品图片| 中文字幕第一区二区| 天堂va蜜桃一区二区三区 | 欧美久久一二三四区| 国产日产亚洲精品系列| 香蕉成人伊视频在线观看| 成人激情小说乱人伦| 日韩视频123| 玉米视频成人免费看| 国产毛片精品视频| 在线不卡中文字幕| 亚洲欧美色一区| 国产伦精品一区二区三区视频青涩| 欧美性感一类影片在线播放| 国产日韩欧美精品一区| 奇米综合一区二区三区精品视频| 色综合天天综合色综合av| 久久―日本道色综合久久| 亚洲美女一区二区三区| 国产成人午夜视频| 欧美另类变人与禽xxxxx| 亚洲综合一区二区三区| 91在线视频免费观看| 久久久青草青青国产亚洲免观| 日韩国产在线观看| 91伊人久久大香线蕉| 精品理论电影在线观看 | 国产精品系列在线| 国产成人午夜精品影院观看视频 | 国精产品一区一区三区mba桃花| 色综合久久久久网| 成人欧美一区二区三区在线播放| 国产91丝袜在线观看| 久久伊人中文字幕| 国内精品国产三级国产a久久| 日韩午夜精品电影| 日韩和欧美的一区| 色综合久久中文综合久久97| 国产欧美日韩麻豆91| 精品一区二区免费在线观看| 日韩一区二区在线看| 天堂蜜桃91精品| 91精品黄色片免费大全| 日韩av一二三| 6080yy午夜一二三区久久| 香蕉成人啪国产精品视频综合网| 欧美色爱综合网| 亚洲国产精品久久久久秋霞影院 | 国产精品久久毛片| 成人av网址在线| 亚洲人成7777| 成人a级免费电影| 亚洲欧洲色图综合| 99久久精品国产一区二区三区| 国产精品久久久久天堂| 国产丶欧美丶日本不卡视频| 久久精品欧美日韩| 不卡一区在线观看| 国精产品一区一区三区mba视频| 顶级嫩模精品视频在线看| 亚洲色图欧洲色图婷婷| 日韩精品专区在线| 午夜精品一区二区三区电影天堂| 亚洲一区二区三区激情| 久久久久久久综合| 欧美一级精品在线| 亚洲精品一线二线三线无人区| 国产精品欧美久久久久一区二区| 成人一区在线看| 亚洲欧美色图小说| 欧美日韩免费电影| 日韩专区一卡二卡| 精品卡一卡二卡三卡四在线| 国产成人综合在线播放| 中文字幕日韩av资源站| 色哟哟精品一区| 日韩中文字幕一区二区三区| 日韩精品自拍偷拍| 高清成人在线观看| 亚洲一区二区三区爽爽爽爽爽| 91精品国产综合久久久久久久| 国产综合久久久久影院| 亚洲视频网在线直播| 99久久精品久久久久久清纯| 亚洲黄色片在线观看| 色域天天综合网| 国产一本一道久久香蕉| 亚洲欧美偷拍三级| 久久久久国产精品人| 天天综合日日夜夜精品| 五月激情综合色| 成人美女在线观看| 国产精品欧美综合在线| 福利电影一区二区| 一区二区欧美国产| 欧美mv和日韩mv的网站| 91丨porny丨蝌蚪视频| 看电影不卡的网站| 亚洲欧美自拍偷拍色图| 日韩欧美在线网站| 99精品视频一区二区| 亚洲chinese男男1069| 精品精品国产高清a毛片牛牛| 99久久精品国产毛片| 久久66热re国产| 亚洲免费观看在线视频| 精品免费日韩av| 欧美图片一区二区三区| 成人美女视频在线观看18| 日韩一区精品视频| 亚洲色欲色欲www在线观看| 欧美电影免费观看高清完整版在| 99国产精品国产精品久久| 日本色综合中文字幕| 亚洲另类中文字| 国产午夜亚洲精品不卡| 欧美丝袜丝nylons| 麻豆视频一区二区| 3d动漫精品啪啪| 九一九一国产精品| 欧美一区二区视频在线观看 |